iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version : V1.1

# MQ6812/MQ6821/MQ6822 Datasheet V1.1

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

| 1.   | Char    | nge History                                    | 6  |
|------|---------|------------------------------------------------|----|
| 2.   | Prod    | uct Overview                                   | 7  |
|      | 2.1     | Features                                       | 7  |
|      | 2.2     | Block Diagram                                  | 11 |
|      | 2.3     | Pin Assignment                                 | 12 |
| З.   | Elect   | ronic Characteristics                          | 22 |
|      | 3.1     | Absolute Maximum Ratings                       | 22 |
|      | 3.2     | Operation Conditions                           | 23 |
|      | 3.3     | DC Characteristics                             | 23 |
|      | 3.4     | AD Conversion Characteristics                  | 25 |
|      | 3.5     | Flash Characteristics                          | 26 |
|      | 3.6     | LCD Characteristics                            | 26 |
| 4.   | Cent    | ral Processing Unit (CPU)                      | 27 |
|      | 4.1     | General Concept                                | 27 |
|      | 4.2     | Addressing Space                               | 27 |
|      | 4.3     | Operation Modes                                | 30 |
|      | 4.4     | Stack Area and Stack Pointer                   | 43 |
|      | 4.5     | Program Counter (PC)                           | 44 |
|      | 4.6     | General-Purpose Register                       | 45 |
|      | 4.7     | Program Status Word (PSW)                      | 47 |
|      | 4.8     | Low Power Consumption Function for Peripherals | 50 |
|      | 4.9     | Key-on Wakeup (KWU)                            | 52 |
| 5. I | Reset I | -unction                                       | 56 |
|      | 5.1     | Reset Control Circuit                          | 56 |
|      | 5.2     | Power-on Reset Circuit                         | 64 |
|      | 5.3     | Voltage Detection Circuit                      | 65 |
| 6. 9 | System  | n Clock Controller                             | 72 |
|      | 6.1     | Configuration                                  | 72 |
|      | 6.2 (   | Control                                        | 73 |
|      | 6.3 F   | Function                                       | 76 |
|      | 6.4     | Warm-up Counter                                | 79 |

汉芝电子股份有限公司 iMQ Technology Inc. Version: V1.1 No. : TDDS01-M6812-EN Name : MQ6812/MQ6821/MQ6822 Datasheet 7.1 Interrupts Latches (IL29 to IL3)......85 Interrupt Enable Register (EIR)......85 7.2 7.3 Interrupt Master Enable Flag (IMF) ......85 7.4 Individual Interrupt Enable Flag (EF29 to EF4)......86 7.5 8.1 8.2 8.3 9.1 9.2 9.3 9.4 9.5 9.6 Analog Input Voltage and AD Conversion Result...... 122 Precautions about the AD Converter ...... 123 9.7 10.1 Watchdog Timer/ Watchdog Timer2 (WDT/WDT2)......124 10.5 10-bit Timer Counters ...... 139 

iMQ Technology Inc. No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| 11.6 The Example of LCD                                               | 188 |
|-----------------------------------------------------------------------|-----|
| 12.Asynchronous Serial Interface (UART)                               | 192 |
| 12.1 Control                                                          | 192 |
| 12.2 Low Power Consumption Function                                   | 196 |
| 12.3 Protection of UART1CR1 and UART1CR2 Registers from Being Changed | 196 |
| 12.4 Activation of STOP, IDLE0 or SLEEP0 Mode                         | 197 |
| 12.5 Transfer Data Format                                             | 197 |
| 12.6 Infrared Data Format Transfer Mode                               | 198 |
| 12.7 Transfer Baud Rate                                               | 199 |
| 12.8 Data Sampling Method                                             | 201 |
| 12.9 Received Data Noise Rejection                                    | 203 |
| 12.10 Transmit/Receive Operation                                      | 204 |
| 12.11 Transmit/Receive Operation                                      | 205 |
| 12.12 Receiving Process                                               | 211 |
| 13. Flash Memory                                                      | 214 |
| 13.1 Flash Memory Control                                             | 214 |
| 13.2 Flash Memory Functions                                           | 215 |
| 13.3 Command Sequence                                                 | 216 |
| 13.4 Access to the Flash Memory Area                                  | 217 |
| 14.Serial Bus Interface(SBI)/ I2C                                     | 219 |
| 14.1 Communication Format                                             | 219 |
| 14.2 Configuration                                                    |     |
| 14.3 Control                                                          | 222 |
| 14.4 Functions                                                        | 227 |
| 14.5 Data transfer of I2C Bus                                         | 239 |
| 14.6 AC Specifications                                                | 246 |
| 15 Synchronous Serial Interface (SIO)                                 | 248 |
| 15.1 Configuration                                                    | 248 |
| 15.2 Control                                                          | 249 |
| 15.3 Low power consumption function                                   | 251 |
| 15.4 Functions                                                        |     |

| 汉芝电子股份有限公司<br>iMQ Technology Inc.                |                                        |                |  |  |  |  |  |  |  |
|--------------------------------------------------|----------------------------------------|----------------|--|--|--|--|--|--|--|
| No. : TDDS01-M6812-EN                            | Name : MQ6812/MQ6821/MQ6822 Datasheet  | Version : V1.1 |  |  |  |  |  |  |  |
| 15.5 Transfer Modes                              |                                        |                |  |  |  |  |  |  |  |
| 15.6 AC Characteristic                           | 15.6 AC Characteristic                 |                |  |  |  |  |  |  |  |
| Appendix A. In-system Programming Function (ISP) |                                        |                |  |  |  |  |  |  |  |
| Appendix B. Product number info                  | Appendix B. Product number information |                |  |  |  |  |  |  |  |
| Appendix C. Package Information                  |                                        |                |  |  |  |  |  |  |  |
| Appendix D. Application Notice                   |                                        |                |  |  |  |  |  |  |  |

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 1. Change History

| Version | Approved Date | Description                                                                                                                                                       |
|---------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V 1.0   | 2018/5/3      | New release.                                                                                                                                                      |
| V1.1    | 2021/2/3      | <ol> <li>Update "CH2.3 Pin Assignment", update MQ6822 pin-assignment<br/>and figure 2.2.</li> <li>Update "Appendex C. Package Information" QFN 32(4x4)</li> </ol> |

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 2. Product Overview

## 2.1 Features

- General information
  - Wide operating voltage : 2.0V ~ 5.5V
     (2.6V ~ 5.5V, when LCD enable)
  - Operating temperature: -40°C ~ 85°C
  - i87 8-bit MCU core

## Memory

- 16K x 8 program Flash memory (endurance 100K times)
- 512 x 8 data memory RAM
- 64 x 8 information block

## ♦ I/O

- 28 bi-direction I/Os 
  2 Hi-driving I/O.
- Two 35mA LED driving (P80/P81) other 27 I/O are 15mA output (excluding P10)
- Max. six 10-bit PPG output
- One16-bit PPG output
- Max. 16 external wake-up pin
- Max. 27 programble pull-up and pulldown I/Os
- 2 UART transfer/receive pins (details description please refer chapter 2.4)

## Instruction cycles

- Instruction cycle can set as 1/1 \ 1/2
   1/4 \ 1/8 fc
- 1ch of UART
- 1 sets of SIO
- 1ch of I<sup>2</sup>C/SIO
- 21 interrupt sources
  - Max. 18 internal interrupt
  - Max 3 external interrupt

## Clock Sources

- External crystal or internal oscillator
- Support 1MHz~16MHz, or 32kHz external crystal
- Internal high oscillator frequency 16MHz
- Internal Low oscillator frequency 24KHz

## LCD

- Max. LCD driver up to 8 COM X 12 SEG (DMA)
- Eight LCD modes: Static, 1/8 duty(1/4 bias, 1/3 bias, 1/2 bias), 1/4 duty(1/3 bias), 1/3 duty (1/3 bias, 1/2 bias), 1/2 duty(1/2 bias).

## Timer/Counter information

- Max. six 10-bit Timer (TCQ · with capture function)
  - TCO00、TCO02、TCO04 with double buffer
  - TCQ01、TCQ03、TCQ05 without double buffer
- One 16-bit Timer (TCA · with capture function)
- Time Base Timer(TBT)
- Watch Dog Timer(WDT)
- Watch Dog Timer 2 (WDT2)
- Warm-up Counter (WUC)
- Real Time Clock (RTC)
- 8-bit divider output (DVO)

## Low Power Operation Modes

8 low power operation modes: STOP,
 SLOW1,SLOW2,IDLE0IDLE1,IDLE2SLEEP0,SLEEP1

## 2set 8-level voltage detect

## 10-bit AD converter(ADC)

- Max. 9 external ADC input
- One internal 1/4 VDD battery measure input pin
- Three ADC internal referenc voltage : 4V,3V,2V
- One external ADC referece voltage, voltage range:2.0~5.5V.

## Page: 7/ 278

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

In-system programming (ISP)

## Package information

- LQFP (7x7)/QFN 32 pin
- SSOP28/SOP28 pin
- SOP/SSOP/DIP20 pin

| Product no.         | MQ6812LQ032HAER                                                 | MQ6812N4032HAER                                                 |  |  |
|---------------------|-----------------------------------------------------------------|-----------------------------------------------------------------|--|--|
| Pin cunt./IOs       | 32<br>(30)                                                      | 32<br>(30)                                                      |  |  |
| Operating voltage   | 2.0~5.5V                                                        | 2.0~5.5V                                                        |  |  |
| Operating temp.     | -40~85C                                                         | -40~85C                                                         |  |  |
| Ext. interrupt      | 16                                                              | 16                                                              |  |  |
| Flash               | 16K Bytes                                                       | 16K Bytes                                                       |  |  |
| RAM                 | 512 Bytes                                                       | 512 Bytes                                                       |  |  |
| ADC                 | 10-bit x 9-CH<br>(1/4 VDD, internal,<br>external) <sup>*1</sup> | 10-bit x 9-CH<br>(1/4 VDD, internal,<br>external) <sup>*1</sup> |  |  |
| LCD                 | 8x12                                                            | 8x12                                                            |  |  |
| Interrupt           | External: 3<br>Internal: 18                                     | External: 3<br>Internal: 18                                     |  |  |
| Internal oscillator | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C     | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C     |  |  |
| External crystal    | 1~16MHz or<br>32768Hz                                           | 1~16MHz or<br>32768Hz                                           |  |  |
| Timer/              | 10bit x 6<br>16bit x 1                                          | 10bit x 6<br>16bit x 1                                          |  |  |
| Counter             | WDT,TBT,<br>RTC,WUC                                             | WDT,TBT,<br>RTC,WUC                                             |  |  |
| PWM/PPG             | 10bit x 6<br>16bit x 1                                          | 10bit x 6<br>16bit x 1                                          |  |  |
| LVD                 | 8 level<br>(+/- 0.1V)* <sup>2</sup>                             | 8 level<br>(+/- 0.1V)* <sup>2</sup>                             |  |  |
| Communication       | UART x 1,<br>SIOx1, I <sup>2</sup> Cx1                          | UART x 1,<br>SIOx1, I <sup>2</sup> Cx1                          |  |  |
| ISP                 | Yes                                                             | YEs                                                             |  |  |
| Package type.       | LQFP32                                                          | OFN32                                                           |  |  |

\*1: "1/4 VDD" means there is one internal 1/4 VDD battery measure input pin. "Internal " means there is internal referenc voltage (4V,3V,2V). " External" means there one ne external ADC referece voltage \*2: There is 2 set of LVD, and each set is 4 level voltage, max. accuracy is +/- 0.1V.

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Product no.            | MQ6812SP028HAER                                                 | MQ6822SP028HAER                                             | MQ6812SS028HAER                                                 |
|------------------------|-----------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------|
| Pin cunt./IOs          | 28<br>(26)                                                      | 28<br>(26)                                                  | 28<br>(26)                                                      |
| Operating<br>voltage   | 2.0~5.5V                                                        | 2.0~5.5V                                                    | 2.0~5.5V                                                        |
| Operating temp.        | -40~85C                                                         | -40~85C                                                     | -40~85C                                                         |
| Ext. interrupt         | 13                                                              | 16                                                          | 13                                                              |
| Flash                  | 16K Bytes                                                       | 16K Bytes                                                   | 16K Bytes                                                       |
| RAM                    | 512 Bytes                                                       | 512 Bytes                                                   | 512 Bytes                                                       |
| ADC                    | 10-bit x 9-CH<br>(1/4 VDD, internal,<br>external) <sup>*1</sup> | 10-bit x 9-CH<br>(1/4 VDD, internal,<br>external)*1         | 10-bit x 9-CH<br>(1/4 VDD, internal,<br>external) <sup>*1</sup> |
| LCD                    | 8x8                                                             | 8x12                                                        | 8x8                                                             |
| Interrupt              | External: 2<br>Internal: 19                                     | External: 3<br>Internal: 15                                 | External: 2<br>Internal: 19                                     |
| Internal<br>oscillator | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C     | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C     |
| External crystal       | 1~16MHz or<br>32768Hz                                           | 1~16MHz or<br>32768Hz                                       | 1~16MHz or<br>32768Hz                                           |
| Timer/                 | 10bit x 6<br>16bit x 1                                          | 10bit x 2<br>16bit x 1                                      | 10bit x 6<br>16bit x 1                                          |
| Counter                | WDT,TBT,<br>RTC,WUC                                             | WDT,TBT,<br>RTC,WUC                                         | WDT,TBT,<br>RTC,WUC                                             |
| PWM/PPG                | 10bit x 6<br>16bit x 1                                          | 10bit x 2<br>16bit x 1                                      | 10bit x 6<br>16bit x 1                                          |
| LVD                    | 8 level<br>(+/- 0.1V) <sup>*2</sup>                             | 8 level<br>(+/- 0.1V) <sup>*2</sup>                         | 8 level<br>(+/- 0.1V) <sup>*2</sup>                             |
| Communication          | UART x 1,<br>SIOx1, I <sup>2</sup> Cx1                          | UART x 1,<br>SIOx1, I <sup>2</sup> Cx1                      | UART x 1,<br>SIOx1, I <sup>2</sup> Cx1                          |
| ISP                    | Yes                                                             | Yes                                                         | Yes                                                             |
| Package type.          | SOP28                                                           | SOP28                                                       | SSOP28                                                          |

\*1: "1/4 VDD" means there is one internal 1/4 VDD battery measure input pin. "Internal " means there is internal referenc voltage (4V,3V,2V). " External" means there one ne external ADC referece voltage \*2: There is 2 set of LVD, and each set is 4 level voltage, max. accuracy is +/- 0.1V.

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version : V1.1

| Product no.         | MQ6821SP020HAER                                                 | MQ6821SS020HAER                                                | MQ6821DP020HAER                                                |
|---------------------|-----------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------------------|
| Pin cunt./IOs       | 20<br>(18)                                                      | 20<br>(18)                                                     | 20<br>(18)                                                     |
| Operating voltage   | 2.0~5.5V                                                        | 2.0~5.5V                                                       | 2.0~5.5V                                                       |
| Operating temp.     | -40~85C                                                         | -40~85C                                                        | -40~85C                                                        |
| Ext. interrupt      | 8                                                               | 8                                                              | 8                                                              |
| Flash               | 16K Bytes                                                       | 16K Bytes                                                      | 16K Bytes                                                      |
| RAM                 | 512 Bytes                                                       | 512 Bytes                                                      | 512 Bytes                                                      |
| ADC                 | 10-bit x 6-CH<br>(1/4 VDD, internal,<br>external) <sup>*1</sup> | 10-bit x6-CH<br>(1/4 VDD, internal,<br>external) <sup>*1</sup> | 10-bit x6-CH<br>(1/4 VDD, internal,<br>external) <sup>*1</sup> |
| Interrupt           | External: 2<br>Internal: 17                                     | External: 2<br>Internal: 17                                    | External: 2<br>Internal: 17                                    |
| Internal oscillator | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C     | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C    | 16MHz<br>+/- 1% @ 25C<br>+/- 2% @ 0~85C<br>+/- 3% @ -40~85C    |
| External crystal    | 1~16MHz or 32768Hz                                              | 1~16MHz or<br>32768Hz                                          | 1~16MHz or<br>32768Hz                                          |
| Timer/              | 10bit x 4<br>16bit x 1                                          | 10bit x 4<br>16bit x 1                                         | 10bit x 4<br>16bit x 1                                         |
| Counter             | WDT,TBT,<br>RTC,WUC                                             | WDT,TBT,<br>RTC,WUC                                            | WDT,TBT,<br>RTC,WUC                                            |
| PWM/PPG             | 10bit x 4<br>16bit x 1                                          | 10bit x 4<br>16bit x 1                                         | 10bit x 4<br>16bit x 1                                         |
| LVD                 | 8 level<br>(+/- 0.1V)*2                                         | 8 level<br>(+/- 0.1V) <sup>*2</sup>                            | 8 level<br>(+/- 0.1V)* <sup>2</sup>                            |
| Communication       | UART x 1,SIO x1                                                 | UART x 1, SIOx 1                                               | UART x 1,SIOx1                                                 |
| ISP                 | Yes                                                             | Yes                                                            | Yes                                                            |
| Package type.       | SOP20                                                           | SSOP20                                                         | DIP20                                                          |

\*1: "1/4 VDD" means there is one internal 1/4 VDD battery measure input pin. "Internal " means there is internal referenc voltage (4V,3V,2V). " External" means there one ne external ADC referece voltage

\*2: There is 2 set of LVD, and each set is 4 level voltage, max. accuracy is +/- 0.1V.

iMQ Technology Inc. No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## 2.2 Block Diagram





## Page: 11/ 278



## Page: 12/ 278

P81 (PPG03B)

P72 (TCA0 / PPGA0B / COMZ)

P73 (<u>KW1</u> 12/COM3)

P83 (PPG05B / COM5)

P82 (PPG04B / COM4)

P23 (SDA / COM6)

P24 (SCL / KWI 8 / COM7

P25 (<u>KW1</u> 9 / SEG0)

汉芝电子股份有限公司 iMQ Technology Inc. No. : TDDS01-M6812-EN Name : MQ6812/MQ6821/MQ6822 Datasheet Version: V1.1 SOP-28/SSOP-28 (LCD: 8COM x 8 SEG) Product No.: MQ6812SP028HAER / MQ6812SS028HAER VSS 0 VDD 28 (XIN) P00 P40 (AIN0 / KWI 0 / OCDCK) 27 (XOUT) P01 P41 (AIN1 / KWL1 / OCDIO) 26 (RESETB) P10 25 P42 (AIN2 / <u>KWI</u> 2) (PPG01B) P71 P43 (AIN3 / <u>KWI</u> 3 / VREF) 24 (COM0 / RX / TX) P90 P44 (AIN4 / <u>KWI</u> 4 / SEG11) 6 23 (COM1 / TX / RX) P91 22 P45 (AIN5 / KWI 5 / SEG10) MQ6812 (PPG02B) P80 21 8 P46 (AIN6 / <u>KWI</u> 6 / SEG9) (PPG03B) P81 20 P47 (AIN7 / <u>KWI</u> 7 / SEG8) 9 (COM2 / PPGA0B / TCA0) P72 10 19 P74 (DVOB / AIN8 / SI / <u>KWI</u> 13 / SEG7) (COM3/<u>KWI</u> 12) P73 11 P76 (INT3 / SCLK / <u>KWI</u> 15 / SEG6) 18 (COM4 / PPG04B) P82 12 P70 (PPG00B / SEG5) 17 (COM5 / PPG05B) P83 P75 (INT2 / SO / KWI 14/ SEG4) 13 16 (COM6 / SDA) P23 15 P24 (SCL / KWI 8 / COM7) 14

Page: 13/ 278



## Page: 14/ 278



Page: 15/ 278

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| 32pin<br>No. | Pin Name                               | LCD<br>(Note 7) | І/О Туре |                                                            | Function Description                                                                                                                                                                                                                                                    |
|--------------|----------------------------------------|-----------------|----------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1            | vss                                    | -               |          | Power                                                      | Negative power supply/ ground,                                                                                                                                                                                                                                          |
| 2<br>3       | P00/XIN<br>P01/XOUT                    | -               | I/O      | Pull-up<br>Pull-down<br>Ext. crystal<br>(High/Low)         | P00 and P01 are bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>XIN and XOUT are pin-shared with P00 and P01 respectively,<br>and are connected to a high/low frequency external crystal<br>for system clock. |
| 4            | P10/RESETB                             | _               | I/O      | Pull-up(note6)                                             | P10 is bi-directional I/O pins, which are software configurable<br>to be with pull-up resistors.<br>RESETB is pin-shared with P10, which is low-active.                                                                                                                 |
| 5            | P71/ PPG01B                            | _               | I/O      | Pull-up<br>Pull-down                                       | P71 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>8-bit timer/counter pin is pin-shared with P71.                                                                                                        |
| 6<br>7       | P90/TXD1/RXD1<br>P91/RXD1/TXD1         | СОМ0<br>СОМ1    | I/O      | Pull-up<br>Pull-down<br>UART<br>LCD                        | P90, P91 are bi-directional I/O pins, which are software configurable to be with pull-up or pull-down resistors.<br>UART pin TXD0/ RXD0, LCD driving pin COM0/ COM1, are pin-shared with P90, P91 respectively.                                                         |
| 8<br>9       | P80/ PPG02B<br>P81/ PPG03B             |                 | I/O      | Open drain                                                 | P80 and P81 are 35mA current driving output.<br>10-bit timer/counter TCQ02 and TCQ03 are pin-shared with<br>P80, P81 respecttivly.                                                                                                                                      |
| 10           | P72/TCA0/PPGA0B                        | COM2            | I/O      | Pull-up<br>Pull-down<br>LCD                                | P72 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>16-bit timer pin TCA0/ PPGA0B,and LCD driving pin is pin-<br>shared with P72.                                                                          |
| 11           | P73/ <u>KWI</u> 12<br>(note 1, note 6) | СОМЗ            | I/O      | Pull-up<br>Pull-down<br>Wake up<br>LCD                     | P73 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>Wakeup input pin <u>KWI</u> 12 and LCD driving pin COM3 is pin-<br>shared with P73.                                                                    |
| 12<br>13     | P82/PPG04B<br>P83/PPG05B               | COM4<br>COM5    | I/O      | Pull-up<br>Pull-down<br>LCD                                | P82 and P83 are bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>10-bit timer/counter TCO04 < TCO05 ,and LCD driving pin<br>COM4 < COM5 are pin-shared with P82 and P83.                                       |
| 14           | P23/SDA                                | COM6            | I/O      | Pull-up<br>Pull-down<br>I <sup>2</sup> C<br>LCD            | P23 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>I <sup>2</sup> C pin SDA and LCD driving pin COM6 is pin-shared with P23. •                                                                            |
| 15           | P24/SCL./ <u>KWI</u> 8 (note 1)        | COM7            | I/O      | Pull-up<br>Pull-down<br>I <sup>2</sup> C<br>Wake up<br>LCD | P24 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>I <sup>2</sup> C pin SCL and wakeup input pin <u>KWI</u> 8,and LCD driving pin<br>COM7/ SEG31 is pin-shared with P24. °                                |

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| 32pin<br>No.         | Pin Name                                                                          | LCD<br>(Note 7)                |     | І/О Туре                                                        | Function Description                                                                                                                                                                                                                                                                          |
|----------------------|-----------------------------------------------------------------------------------|--------------------------------|-----|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16                   | P25/ <u>KWI</u> 9 (note 1)                                                        | SEG0                           | I/O | Pull-up<br>Pull-down<br>Wake up<br>LCD                          | P25 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>Wakeup input pin <u>KWI</u> 9 and LCD driving pin SEG0 is pin-<br>shared with P25.                                                                                           |
| 17<br>18             | P26/ <u>KWI</u> 10<br>P27/ <u>KWI</u> 11<br>(注1)                                  | SEG 1<br>SEG 2                 | I/O | Pull-up<br>Pull-down<br>Wake up<br>LCD                          | P26 and P27 are bi-directional I/O pins, which are software configurable to be with pull-up or pull-down resistors.<br>Wakeup input pin <u>KWI</u> 10, <u>KWI</u> 11 ,and LCD driving pin SEG1, SEG2 are pin-shared with P26, P27 respectiely.                                                |
| 19                   | P77/INT4/SS                                                                       | SEG3                           | I/O | Pull-up<br>Pull-down<br>Ext. interrupt<br>SIO<br>LCD            | P77 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>External interrupt input pin INT4 and (SIO)SS, and LCD driving<br>pin SEG3 is pin-shared with P77.                                                                           |
| 20                   | P75/INT2/ SO/ <u>KWI</u> 14<br>(note 1)                                           | SEG4                           | I/O | Pull-up<br>Pull-down<br>Ext. interrupt<br>SIO<br>Wake up<br>LCD | P75 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>External interrupt input pin INT2, SIO pin SO, wakeup input pin<br><u>KWI</u> 14 and LCD driving SEG4 is pin-shared with P75.                                                |
| 21                   | P70/ PPG00B                                                                       | SEG5                           | I/O | Pull-up<br>Pull-down<br>LCD                                     | <ul> <li>P70 is bi-directional I/O pins, which are software configurable to be with pull-up or pull-down resistors.</li> <li>8-bit timer/counter pin PPG01B and LCD driving pin SEG5 is pin-shared with P70.</li> </ul>                                                                       |
| 22                   | P76/INT3/SCLK/ <u>KWI</u> 15<br>(注1)                                              | SEG6                           | I/O | Pull-up<br>Pull-down<br>SIO<br>Wake up<br>LCD                   | P76 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>SIO pin SCLK and wakeup input pin <u>KWI</u> 15 and LCD driving<br>pin SEG6 is pin-shared with P76.                                                                          |
| 23                   | P74/DVOB/AIN8/SI/ <u>KWI</u> 13<br>(note1,note 2, note 8)                         | SEG7                           | I/O | Pull-up<br>Pull-down<br>ADC input<br>SIO<br>Wakeup<br>LCD       | P74 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>ADC input pin AIN8 and SIO pin SI, DVO, wakeup input pin <u></u><br><u>KWI</u> 13, and LCD driving pin SEG7 is pin-shared with P74.                                          |
| 24<br>25<br>26<br>27 | P47/AIN7/KWI7<br>P46/AIN6/KWI6<br>P45/AIN5/KWI5<br>P44/AIN4/KWI4<br>(note1,note2) | SEG8<br>SEG9<br>SEG10<br>SEG11 | I/O | Pull-up<br>Pull-down<br>ADC input<br>Wakeup<br>LCD              | P47,P46,P45, and P44 are bi-directional I/O pins, which are<br>software configurable to be with pull-up or pull-down resistors.<br>ADC input AIN7, AIN6,AIN5,AIN4 and wakeup pin <u>KWI 7, KWI</u><br>6, <u>KWI</u> 5, <u>KWI 4</u> are pin-shared with P47, P46,P45 and P44<br>respectively. |
| 28                   | P43/AIN3/ <u>KWI</u> 3/VREF<br>(note1, note2)                                     | -                              | I/O | Pull-up<br>Pull-down<br>ADC input<br>Wakeup                     | P43 is bi-directional I/O pins, which are software configurable to be with pull-up or pull-down resistors.<br>ADC input pin AIN3 and wakeup pin <u>KWI</u> 3, VREF is pin-shared with P43.                                                                                                    |

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| 32pin<br>No. | Pin Name                                                                                                | LCD<br>(Note 7) |           | І/О Туре                         | Function Description                                                                                                                                                                                                                                             |
|--------------|---------------------------------------------------------------------------------------------------------|-----------------|-----------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30           | P42/AIN2/ <u>KWI</u> 2<br>P41/AIN1/ <u>KWI</u> 1/OCDIO<br>P40/AIN0/ <u>KWI</u> 0/OCDCK<br>(note1,note2) | _               | I/O       | Pull-down<br>ADC input<br>Wakeup | P42,P41,and P40 are bi-directional I/O pins, which are<br>software configurable to be with pull-up or pull-down resistors.<br>ADC input AIN2, AIN1,AIN0 and wakeup pin <u>KWI 2 ` KWI</u> 1 `<br><u>KWI</u> 0 are pin-shared with P42, P41 and P40 respectively. |
| 32           | VDD                                                                                                     |                 | Pow<br>er |                                  | Positive power supply                                                                                                                                                                                                                                            |

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| 20pin<br>No. | Pin Name                                 | І/О Туре |                                                                 | Function Description                                                                                                                                                                                                                                                    |
|--------------|------------------------------------------|----------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1            | VSS                                      | Power    |                                                                 | Negative power supply/ ground,                                                                                                                                                                                                                                          |
| 2<br>3       | P00/XIN<br>P01/XOUT                      | I/O      | Pull-up<br>Pull-down<br>Ext. crystal<br>(High/Low)              | P00 and P01 are bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>XIN and XOUT are pin-shared with P00 and P01 respectively,<br>and are connected to a high/low frequency external crystal<br>for system clock. |
| 4            | P10/RESETB                               | I/O      | Pull-up(note6)                                                  | P10 is bi-directional I/O pins, which are software<br>configurable to be with pull-up resistors.<br>RESETB is pin-shared with P10, which is low-active.                                                                                                                 |
| 5            | P71/TCQ01/PPG01B                         | I/O      | Pull-up<br>Pull-down                                            | P71 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>8-bit timer/counter pin is pin-shared with P71.                                                                                                        |
| 6<br>7       | P90/TXD1/RXD1<br>P91/RXD1/TXD1           | I/O      | Pull-up<br>Pull-down<br>UART<br>LCD                             | P90, P91 are bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>UART pin TXD0/ RXD0, LCD driving pin COM0/ COM1, arepin-<br>shared with P90, P91 respectively.                                                   |
| 8            | P72/TCA0/PPGA0B                          | I/O      | Pull-up<br>Pull-down<br>LCD                                     | P72 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>16-bit timer pin TCA0/ PPGA0B,and LCD driving pin is pin-<br>shared with P72.                                                                          |
| 9<br>10      | P82/PPG04B<br>P83/PPG05B                 | I/O      | Pull-up<br>Pull-down<br>LCD                                     | P82 and P83 are bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>10-bit timer/counter TCQ04 < TCQ05 ,and LCD driving pin<br>COM4 < COM5 are pin-shared with P82 and P83.                                       |
| 11           | P75/INT2/ SO/ <u>KWI</u> 14<br>(note 1)  | I/O      | Pull-up<br>Pull-down<br>Ext. interrupt<br>SIO<br>Wake up<br>LCD | P75 is bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>External interrupt input pin INT2, SIO pin SO, wakeup input pin<br><u>KWI</u> 14 and LCD driving SEG4 is pin-shared with P75.                          |
| 12           | P70/ PPG00B                              | I/O      | Pull-up<br>Pull-down<br>LCD                                     | P70 is bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>8-bit timer/counter pin PPG01B and LCD driving pin SEG5 is<br>pin-shared with P70.                                                                     |
| 13           | P76/INT3/SCLK/ <u>KWI</u> 15<br>(note 1) | I/O      | Pull-up<br>Pull-down<br>SIO<br>Wake up<br>LCD                   | P76 is bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>SIO pin SCLK and wakeup input pin <u>KWI</u> 15 and LCD driving<br>pin SEG6 is pin-shared with P76.                                                    |

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| 20pin<br>No.   | Pin Name                                                                                                | І/О Туре |                                                     | Function Description                                                                                                                                                                                                                                             |
|----------------|---------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14             | P74/DVOB/AIN8/SI/ <u>KWI</u> 13<br>(note1,note 2, note 8)                                               | I/O      | Pull-up<br>Pull-down<br>ADC input<br>SIO<br>Wakeup  | P74 is bi-directional I/O pins, which are software configurable<br>to be with pull-up or pull-down resistors.<br>ADC input pin AIN8 and SIO pin SI, DVO, wakeup input pin_<br><u>KWI</u> 13, and LCD driving pin SEG7 is pin-shared with P74.                    |
| 15             | P44/AIN4/ <u>KWI</u> 4<br>(note1,note2)                                                                 | I/O      | Pull-up<br>Pull-down<br>ADC input<br>Wakeup         | P44 is bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>ADC input pin AIN4 and wakeup pin <u>KWI</u> 4 is pin-shared with<br>P43.                                                                       |
| 16             | P43/AIN3/ <u>KWI</u> 3/VREF<br>(note1, note2)                                                           | I/O      | Pull-up<br>Pull-down<br>ADC input<br>Wakeup         | P43 is bi-directional I/O pins, which are software<br>configurable to be with pull-up or pull-down resistors.<br>ADC input pin AIN3 and wakeup pin <u>KWI</u> 3, VREF is pin-<br>shared with P43.                                                                |
| 17<br>18<br>19 | P42/AIN2/ <u>KWI</u> 2<br>P41/AIN1/ <u>KWI</u> 1/OCDIO<br>P40/AIN0/ <u>KWI</u> 0/OCDCK<br>(note1,note2) | I/O      | Pull-up<br>Pull-down<br>ADC input<br>Wakeup<br>OCDE | P42,P41,and P40 are bi-directional I/O pins, which are<br>software configurable to be with pull-up or pull-down resistors.<br>ADC input AIN2, AIN1,AIN0 and wakeup pin <u>KWI 2 × KWI</u> 1 ×<br><u>KWI</u> 0 are pin-shared with P42, P41 and P40 respectively. |
| 20             | VDD                                                                                                     | Power    |                                                     | Positive power supply                                                                                                                                                                                                                                            |

Note 1 : <u>KWI</u> 0~<u>KWI</u> 15 can define to system wake up input pin. <u>KWI</u> 0~<u>KWIZ</u> are pin-shared with P40~P47, and <u>KWI</u> 8~<u>KWI</u> 15 are pin-shared with P24~P27, 73~P76 respectively.

Note 2 : AIN0~AIN8 and AIN13~AIN15 are10-bit ADC input pins.

Note 3: OCD pin are VSS, VDD, P10, P40 and P41. Please note, under OCDE mode, P10,P40 and P40 can not execute the pin function.

Note4: LCD enablem please set LCD driving pin/COM and SEG) as input mode. And keep LCD operating voltage same with VDD of MCU.

Note5 : If using P74 as ADC input/AIN8), and also enable other ADC input pin/AIN), it will cost extra power in stop mode. Please avoid P74 as AIN function/AIN8) if possible.

Note6: The I/O pins which need to be pull-high or pull-low should be connected to VDD or GND through a resistor (resistance >100ohm). To connect I/O pins to VDD or GND directly should be avoided.

## Page: 20/ 278

Figure 2.2 is MQ6812/MQ6822/MQ6821 suggestion external reference circuit · as below 3 parts:

- 1. Add 10uF and 0.1uF capacitance parallel connection to VDD and VSS. In order to avoid power surge or noise effect, it can also enhance MCU EFTB performance. The capacitance position should be close to VDD and VSS pin as close as possible.
- 2. Use ADC function, please series a 100ohm and 1nF capacitance to groud. This can filter noise.
- 3. Connecting 0.1uF capacitor where is near IC, and add (10uF +0.1 uF) capacitor closed to the power jack are recommended. Use ADC and ADC external reference voltage, please add 10uF and 0.1uF capacitance parallel connection, this can filter noise.



Figure 2.2 recommended external circuit

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 3. Electronic Characteristics

## 3.1 Absolute Maximum Ratings

The absolute maximum ratings are rated value which must not be exceeded during operation, even for an instant. Any one of the ratings must not be exceeded. If any absolute maximum rating is exceeded, a device may break down or its performance may be degraded, causing it to catch fire or explode resulting in injury to the user. Thus, when designing products which include this device, ensure that no absolute maximum rating value will ever be exceeded.

|                        |                   |                                   | (\                            | $V_{SS} = 0V$ |  |
|------------------------|-------------------|-----------------------------------|-------------------------------|---------------|--|
| Parameter              | Symbol            | Pins                              | Max.                          | Unit          |  |
| Operating voltage      | V <sub>DD</sub>   |                                   | -0.3 to 6.0                   | V             |  |
| Input voltage          | V <sub>IN</sub>   | All I/O pins                      | -0.3 to $V_{\text{DD}}$ + 0.3 | V             |  |
| Output voltage         | V <sub>OUT</sub>  | All I/O pins                      | -0.3 to $V_{\text{DD}}$ + 0.3 | V             |  |
|                        | I <sub>OUT1</sub> | P10 (IOL)                         | 15                            |               |  |
| Output current         | I <sub>OUT2</sub> | All I/O pins ,excluding P10 (IOL) | 40                            | mA            |  |
| (per-pin)              | I <sub>OUT3</sub> | All I/O pins (IOH)                | -15                           |               |  |
|                        | I <sub>OUT4</sub> | P80/P81 LED driving port)         | 60                            |               |  |
|                        | $\Sigma I_{OUT1}$ | All I/O pins (IOL)                | 120                           | mΛ            |  |
| Output current (total) | $\Sigma I_{OUT2}$ | All I/O pins (IOH)                | 60                            | mA            |  |
| Storage temperature    | T <sub>STG</sub>  |                                   | -40 to 125                    | °C            |  |
| Operating temperature  | T <sub>OPR</sub>  |                                   | -40 to 85                     | °C            |  |

iMQ reserves the right to change the information in this document without prior notice. Please contact iMQ to obtain the latest version of product specification before placing your order. Use of iMQ devices in life support is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless iMQ from any and all damages, claims, suits or expenses resulting from such use.

## Page: 22/ 278

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## 3.2 Operation Conditions

|            |                              |                   |                                              |                                            | $(V_{SS} = $  | OV, T <sub>OPR</sub> = | -40 to 85             | °C)  |
|------------|------------------------------|-------------------|----------------------------------------------|--------------------------------------------|---------------|------------------------|-----------------------|------|
| Parame     | eter                         | Symb<br>ol        | Pins                                         | Condition                                  | Min           | Тур.                   | Max                   | Unit |
| Supply vo  | ltage                        | V <sub>DD</sub>   | LCD disable                                  |                                            | 2.0           | -                      | 5.5                   | V    |
| Supply Vo  | lage                         | v DD              | LCD enable                                   | 所有工作模式                                     | 2.6           | -                      | 5.5                   | V    |
| Input high | n level                      | VIH               | All I/O pins                                 | MALIFIKA                                   | $V_{DD}x0.75$ | -                      | V <sub>DD</sub>       | V    |
| Input low  | level                        | VIL               | All I/O pins                                 |                                            | 0             | -                      | V <sub>DD</sub> x0.25 | V    |
|            | Ext.<br>crystal<br>(high)    | f <sub>C</sub>    | XIN, XOUT                                    |                                            |               | -                      | 16                    | MHz  |
|            | Ext.<br>crystal<br>(low)     | f <sub>CL</sub>   | XIN, XOUT (32.768KHz)                        | V <sub>DD</sub> = 2.0 to 5.5V              | 30.0          | 32.768                 | 34.0                  | KHz  |
| Clock      |                              |                   |                                              | V <sub>DD</sub> = 2.0 to 5.5V<br>25°C      | -1%           |                        | +1%                   | MHz  |
| Frequency  | Internal<br>crystal          |                   | FSCTRL <fosccks>="01" - 16MHz</fosccks>      | V <sub>DD</sub> = 2.0 to 5.5V<br>0°C ~85°C | -2%           | 16.00                  | +2%                   | MHz  |
| (high)     |                              |                   | V <sub>DD</sub> = 2.0 to 5.5V<br>-40°C ~85°C | -3%                                        |               | +3%                    | MHz                   |      |
|            | Internal<br>crystal<br>(low) | f <sub>OSCL</sub> | 24KHz                                        | V <sub>DD</sub> = 2.0 to 5.5V              | -             | 24                     | -                     | KHz  |
|            | System<br>clock              | f <sub>ссск</sub> | Set CGCR <fcgcksel></fcgcksel>               | V <sub>DD</sub> = 2.0 to 5.5V              | 0.125         | -                      | 16                    | MHz  |

## 3.3 DC Characteristics

|                       |                  |                                                          |                                                   | (V <sub>SS</sub> = | • OV, T <sub>OPR</sub> | = -40 to | 85°C) |
|-----------------------|------------------|----------------------------------------------------------|---------------------------------------------------|--------------------|------------------------|----------|-------|
| Parameter             | Symbol           | Pins                                                     | Condition                                         | Min                | Тур.                   | Max      | Unit  |
| Hysteresis<br>voltage | V <sub>HS</sub>  | All I/O pins                                             |                                                   | -                  | 0.9                    | -        | V     |
| Input current         | I <sub>IN</sub>  | All I/O pins                                             | $V_{DD} = 5.5V$                                   | -                  |                        | ±2       | μA    |
| Pull-up<br>resistance | R <sub>UP</sub>  | All I/O pins · excluding<br>P80/P81 · P10 RESETB disalbe | V <sub>IN</sub> = 5.5V / 0V                       | 30                 | 50                     | 70       | ΚΩ    |
| Pull-down             |                  | All I/O pins ` excluding                                 | $V_{DD}/V_{IN} = 5.5V$                            | 27.5               | 55                     | 88       | ΚΩ    |
| resistance            | R <sub>DN</sub>  | P10/P80/P81                                              | $V_{DD}/V_{IN} = 2.0V$                            | -                  | 200                    | -        | KΩ    |
|                       | I <sub>OL1</sub> | P10                                                      |                                                   | 3.0                | 5.0                    |          | mA    |
| Output                | I <sub>OL2</sub> | All I/O pins · excluding<br>P10/P80/P81                  | V <sub>DD</sub> = 5.5V<br>V <sub>OL</sub> = 0.55V | 9.0                | 15.0                   | -        | mA    |
| leakage               | I <sub>OL3</sub> | P80/P81                                                  |                                                   | 21.0               | 35.0                   | -        | mA    |
| current               | I <sub>OH1</sub> | All I/O pins · excluding<br>P80/P81                      | $V_{DD} = 5.5V$                                   | 3.0                | 5.0                    | _        | mA    |
|                       | I <sub>OH2</sub> | P80/P81                                                  | V <sub>OH</sub> = 4.95V                           | 9.0                | 15.0                   | -        | mA    |

Note2 : Data in "Typ." column is at  $T_{OPR} = 25^{\circ}C$ ,  $V_{DD} = 5.0V$ , unless otherwise stated.

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

|                                           |                   |                                                                      | $(V_{SS} = 0V, T_{OPR} = 25^{\circ}C)$ |      |     | °C)  |
|-------------------------------------------|-------------------|----------------------------------------------------------------------|----------------------------------------|------|-----|------|
| Parameter                                 | Symbol            | Condition                                                            | Min                                    | Тур. | Max | Unit |
| Operating current in<br>NORMAL 1, 2 modes |                   | $V_{DD} = 5.5V$                                                      |                                        | 3.8  | 4.4 |      |
| Operating current in IDLE0, 1, 2 modes    |                   | $f_{cgck} = \frac{16.0 \text{ MHz}}{f_{S}}$ $f_{S} = 24 \text{ KHz}$ |                                        | 2.2  | 2.6 |      |
| Operating current in NORMAL 1, 2 modes    |                   | $V_{DD} = 5.5V$                                                      |                                        | 3.1  | 3.7 | mA   |
| Operating current in IDLE0, 1, 2 modes    |                   | f <sub>cgck</sub> = <u>8.0 MHz</u><br>f <sub>S</sub> = 24 KHz        |                                        | 2.0  | 2.4 |      |
| Operating current in<br>SLOW1 modes       | - I <sub>DD</sub> |                                                                      |                                        | 32   | 45  |      |
| Operating current in<br>SLEEP1 modes      |                   | $V_{DD} = 3.0V$<br>$f_s = 24$ KHz                                    |                                        | 19   | 28  |      |
| Operating current in<br>SLEEP0 modes      |                   |                                                                      |                                        | 19   | 28  | μΑ   |
| Operating current in<br>STOP modes        |                   | V <sub>DD</sub> = 5.5V                                               | _                                      | 8    | 12  |      |

Note1 : Data in "Typ." column is at Torr = 25°C, VDD = 5.0V, unless otherwise stated.

Note2 : Each supply current in SLOW2 mode is equivalent to that in IDLE0, IDLE1 and IDLE2 modes.

|                                           | $(V_{SS} = 0V, T_{OPR} = -40 \text{ to } 85)$ |                                                                      |     |      |     | 85°C) |
|-------------------------------------------|-----------------------------------------------|----------------------------------------------------------------------|-----|------|-----|-------|
| Parameter                                 | Symbol                                        | Condition                                                            | Min | Тур. | Max | Unit  |
| Operating current in<br>NORMAL 1, 2 modes |                                               | $V_{DD} = 5.5V$                                                      | -   | 3.8  | 4.8 |       |
| Operating current in IDLE0, 1, 2 modes    |                                               | $f_{cgck} = \frac{16.0 \text{ MHz}}{f_{S}}$ $f_{S} = 24 \text{ KHz}$ |     | 2.2  | 3.0 |       |
| Operating current in<br>NORMAL 1, 2 modes |                                               | $V_{DD} = 5.5V$                                                      | -   | 3.1  | 4.1 | mA    |
| Operating current in IDLE0, 1, 2 modes    |                                               | $f_{cgck} = \frac{8.0 \text{ MHz}}{f_S}$<br>$f_S = 24 \text{ KHz}$   |     | 2.0  | 2.8 |       |
| Operating current in<br>SLOW1 modes       | - I <sub>DD</sub>                             |                                                                      | -   | 32   | 148 |       |
| Operating current in<br>SLEEP1 modes      |                                               | $V_{DD} = 3.0V$<br>$f_s = 24 \text{ KHz}$                            |     | 19   | 129 |       |
| Operating current in<br>SLEEP0 modes      |                                               |                                                                      |     | 19   | 128 | μA    |
| Operating current in<br>STOP modes        |                                               | V <sub>DD</sub> = 5.5V                                               |     | 8    | 92  |       |

Note1 : Data in "Typ." column is at Topr = 25°C, VDD = 5.0V, unless otherwise stated.

Note2 : Each supply current in SLOW2 mode is equivalent to that in IDLE0, IDLE1 and IDLE2 modes.

Name : MQ6812/MQ6821/MQ6822 Datasheet

~ /

 $\alpha (\gamma \gamma \gamma) (\gamma \gamma \gamma)$ 

Version: V1.1

## 3.4 AD Conversion Characteristics

|                                          |                  | $(V_{SS} = 0V, 2.7V)$                      | $ \geq V_{DD} $ | $\geq$ 5.5V, | $I_{OPR} = Z_{2}^{2}$ | S () |
|------------------------------------------|------------------|--------------------------------------------|-----------------|--------------|-----------------------|------|
| Parameter                                | Symbol           | Condition                                  | Min             | Тур.         | Max                   | Unit |
| Analog Reference Voltage                 | V <sub>REF</sub> | -                                          |                 |              | V <sub>DD</sub>       | V    |
| Analog input voltage range               | VAIN             | -                                          | V <sub>SS</sub> |              | $V_{DD}$              | V    |
| Conversion Time                          |                  | fcgck = 2MHz<br>ADCCR2 <ack> = "000"</ack> | -               | 16.0         | -                     | μs   |
| Differential Nonlinearity Error<br>(DNL) |                  | -                                          | -               |              | ±2.0                  | LSB  |
| Integral Nonlinearity Error<br>(INL)     |                  | -                                          | -               |              | ±2.0                  | LSB  |
| Zero Point Error                         |                  | -                                          |                 |              | ±2.0                  | LSB  |
| Full Scale Error                         |                  | -                                          |                 |              | ±2.0                  | LSB  |
| Total Error                              |                  | -                                          |                 |              | ±2.0                  | LSB  |

< F F) / T

| Barameter                                | Sumbol           | Condition                                  | Min | Tre  | Max             | Unit |
|------------------------------------------|------------------|--------------------------------------------|-----|------|-----------------|------|
| Parameter                                | Symbol           | Condition                                  | Min | Тур. | Max             | Unit |
| Analog Reference Voltage                 | V <sub>REF</sub> | -                                          |     |      | $V_{DD}$        | V    |
| Analog input voltage range               | V <sub>AIN</sub> | -                                          | Vss | -    | V <sub>DD</sub> | V    |
| Conversion Time                          |                  | fcgck = 2MHz<br>ADCCR2 <ack> = "001"</ack> | _   | 32.0 |                 | μs   |
| Differential Nonlinearity Error<br>(DNL) |                  | -                                          | -   | -    | ±4.0            | LSB  |
| Integral Nonlinearity Error<br>(INL)     |                  | -                                          | _   | _    | ±4.0            | LSB  |
| Zero Point Error                         |                  | -                                          | -   | -    | ±4.0            | LSB  |
| Full Scale Error                         |                  | -                                          | -   | -    | ±4.0            | LSB  |
| Total Error                              |                  | -                                          |     |      | ±4.0            | LSB  |

Note1: The total error includes all errors except a quantization error, and is defined as the maximum deviation from the ideal conversion line.

Note 2 : The voltage to be input to the AIN input pin must be within the range  $V_{REF}$  to  $V_{SS}$ . If a voltage outside this range is input, converted values will become indeterminate, and converted values of other channels will be affected.

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## 3.5 Flash Characteristics

|                                               | $(V_{SS} = 0V, 2)$                     | $2.0V \leq V_{I}$ | $_{\rm DD} \leq 5.5 V_{\rm c}$ | , T <sub>OPR</sub> = -40 | to 85°C) |
|-----------------------------------------------|----------------------------------------|-------------------|--------------------------------|--------------------------|----------|
| Parameter                                     | Condition                              | Min               | Тур.                           | Max                      | Unit     |
| Number of guaranteed write to<br>flash memory |                                        | -                 |                                | 100,000                  | times    |
| Flash memory write time                       |                                        |                   |                                | 40                       | μs       |
|                                               | chip erase                             | -                 | -                              | 40                       |          |
| Flash memory erase time                       | sector erase<br>(1 sector = 128 Bytes) | -                 | -                              | 5                        | ms       |

## 3.6 LCD Characteristics

|                       |                 |                                       |      | (V <sub>SS</sub> = | = 0V, T <sub>OPR</sub> = | = 25°C) |
|-----------------------|-----------------|---------------------------------------|------|--------------------|--------------------------|---------|
| Parameter             | Symbol          | Condition                             | Min  | Тур.               | Max                      | Unit    |
| LCD operating volateg | V <sub>DD</sub> |                                       | 2.6  | -                  | 5.5                      | V       |
|                       |                 | 1/4 bias LCD, V <sub>DD</sub> = 5.0V  | 3.19 | 3.75               | 4.31                     | V       |
| LCD bias output 1     | V <sub>L1</sub> | 1/3 bias LCD, V <sub>DD</sub> = 5.0V  | 2.83 | 3.33               | 3.83                     | V       |
|                       |                 | 1/2 bias LCD, V <sub>DD</sub> = 5.0V  | 2.12 | 2.50               | 2.88                     | V       |
|                       | V <sub>L2</sub> | 1/42 bias LCD, V <sub>DD</sub> = 5.0V | 2.12 | 2.50               | 2.88                     | V       |
| LCD bias output 2     |                 | 1/32 bias LCD, V <sub>DD</sub> = 5.0V | 1.42 | 1.67               | 1.92                     | V       |
| LCD bias output 3     | V <sub>L3</sub> | 1/4 bias LCD, V <sub>DD</sub> = 5.0V  | 1.06 | 1.25               | 1.44                     | V       |

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 4. Central Processing Unit (CPU)

## 4.1 General Concept

MQ6812/MQ6821 adopts i87 8-bit MCU core with embedded 16KB program flash memory, and 128 x8 bit data flash. The introduction of the powerful central processing unit (CPU) can be divided into two major parts: (1) Addressing Space of Program / Data Memory and Special Function Registers (SFR), (2) Operation Modes.

## 4.2 Addressing Space

Figure 4.1 shows the addressing space of MQ6812/MQ6821, including SRF1, SRF2, SFR3, RAM and program memory (Flash) memory. Except main 16KB program flash memory, and 128 x8 bit data flash, MQ6812/MQ6821 also provide 64x8 bit info. block(0x7E40  $\cong$  0x7E7F).Info block can save important product information, e.g. information of writer.



Figure 4.1 Addressing Map of MQ6812/MQ6821

Page: 27 / 278

## 4.2.1 Program Memory- Flash

The program memory (Flash) is used to store the program instructions which are to be executed. It also contains data, table, and interrupt entries, and is organized into 16K + 128 bytes format which is addressed by the PC and table pointer. The Flash ranges of MQ6812/MQ6821 is from 0xC000 to 0xFFFF (16K bytes) The data flash ranges of MQ6812/MQ6821 is from 0x7E80 to 0x7EFF (128x8) .The 128 x 8 byte area can use for saving user information, e.g. product ID.  $\circ$ 

## 4.2.2 RAM Data Memory- RAM

The RAM is mapped to 0x0040 to 0x023F(512x 8 byte) in the data area after reset release. Note that the contents of the RAM become unstable when the power is turned on and immediately after a reset is released. To execute the program by using the RAM, transfer the program to be executed in the initialization routine.

## 4.2.3 Special Function Register-SFR

The SFR is mapped to 0x0000 to 0x003F (SFR1), 0x0F00 to 0x0FFF (SFR2) and 0x0E40 to 0x0EFF (SFR3) in the data area after reset release.

note: do not read SFR which is system reserved.

iMQ reserves the right to change the information in this document without prior notice. Please contact iMQ to obtain the latest version of product specification before placing your order. Use of iMQ devices in life support is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless iMQ from any and all damages, claims, suits or expenses resulting from such use.

## Page: 28/ 278

## iMQ Technology Inc. No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

|        | SER 1                     |
|--------|---------------------------|
|        |                           |
| 0x0000 | PODR                      |
| 0x0001 | P1DR                      |
| 0x0002 | PZDR                      |
| 0x0003 | 1201                      |
|        | P4DR                      |
| 0x0004 | P4DK                      |
| 0x0005 |                           |
| 0x0006 |                           |
| 0x0007 | P7DR                      |
| 0x0008 | P8DR                      |
| 0x0009 | P9DR                      |
| 0x000A | 170%                      |
|        |                           |
| 0x000B |                           |
| 0x000C |                           |
| 0x000D | POPRD                     |
| 0x000E | P1PRD                     |
| 0x000F | P2PRD                     |
| 0x0010 | 12110                     |
| 0x0011 | P4PRD                     |
|        | P4PKD                     |
| 0x0012 |                           |
| 0x0013 |                           |
| 0x0014 | P7PRD                     |
| 0x0015 | P8PRD                     |
| 0x0016 | P9PRD                     |
| 0x0017 | 17/10                     |
|        |                           |
| 0x001E |                           |
| 0x001E | SIOOCR                    |
|        |                           |
| 0x0020 | SIOOSR                    |
| 0x0021 | SIOOBUF                   |
| 0x0022 | SBIOCR1                   |
| 0x0023 | SBIOCR2/SBIOSR2<br>I2COAR |
| 0x0024 | 12COAR                    |
| 0x0025 | SBIODBR                   |
| 0x0026 | 3010001                   |
| 0x0020 |                           |
| 0x0029 |                           |
| 0x002A | T00MOD                    |
| 0x002B | T01MOD                    |
|        | TOTMOD                    |
| 0x002C | T001CR                    |
| 0x002D | TAODRAL                   |
| 0x002E | TAODRAH                   |
| 0x002F | TAODRBL                   |
| 0x0030 | TAODRBH                   |
| 0x0031 | TAOMOD                    |
|        | TAOR                      |
| 0x0032 |                           |
| 0x0033 | TAOSR                     |
| 0x0034 | ADCCR1                    |
| 0x0035 | ADCCR2                    |
| 0x0036 | ADCCRL                    |
| 0x0037 | ADCCRH                    |
| 0x0037 | DVOCR                     |
|        |                           |
| 0x0039 | TBTCR                     |
| 0x003A | EIRL                      |
| 0x003B | EIRH                      |
| 0x003C | EIRE                      |
| 0x003D | EIRD                      |
| 0x003E | LIND                      |
| 0x003F | PSW                       |
| 000031 | FSW                       |

| SFR2                                       |
|--------------------------------------------|
| POPD                                       |
| 0300                                       |
| PZPD                                       |
| P4PD                                       |
| 1110                                       |
|                                            |
| P7PD<br>P8PD                               |
| P8PD                                       |
| P9PD                                       |
|                                            |
|                                            |
| POCR<br>P1CR<br>P2CR                       |
| PICR                                       |
| P2CR                                       |
| DACD                                       |
| P4CR                                       |
|                                            |
| P7CR<br>P8CR                               |
| P8CR                                       |
| P9CR                                       |
|                                            |
|                                            |
| POPU                                       |
| PIPU                                       |
| P2PU                                       |
|                                            |
| 07011                                      |
| P7PU<br>P8PU                               |
| P8PU<br>P9PU                               |
| 1910                                       |
|                                            |
|                                            |
| POFC                                       |
| 0350                                       |
| P2FC                                       |
| P4FC                                       |
| LALC .                                     |
|                                            |
| P7FC                                       |
| P8FC                                       |
| P9FC                                       |
|                                            |
| P2OUTCR                                    |
| 1200101                                    |
|                                            |
| UARTICRI<br>UARTICR2<br>UARTIDR<br>UARTISR |
| UART1CR2                                   |
| UARTIDR                                    |
| UARTISR<br>TD1BUF / RD1BUF                 |
| TO BOF / KD BOF                            |
|                                            |
|                                            |
| POFFCR0<br>POFFCR1<br>POFFCR2              |
| POFFCR1                                    |
| POFFCR2<br>POFFCR3                         |
| POFFCR3                                    |
|                                            |
|                                            |

0x0F00 0x0F01

0x0F02 0x0F03

0x0F04

0x0F05

0x0F06

0x0F07

0x0F08

0x0F09 0x0F0A

0x0F19 0x0F1A 0x0F1B

0x0F1C 0x0F1D

0x0F1E 0x0F1F

0x0F20 0x0F21

0x0F22

0x0F23

0x0F24

0x0F25

0x0F26

0x0F27 0x0F28

0x0F29

0x0F2D 0x0F2E

0x0F2F 0x0F30

0x0F31 0x0F32

0x0F33 0x0F34

0x0F35

0x0F36

0x0F37

0x0F38 0x0F39

0x0F3A 0x0F3B

0x0F3C 0x0F3D

0x0F3E

0x0F43

0x0F53

0x0F54 0x0F55

0x0F56 0x0F57

0x0F58 0x0F59

0x0F73

0x0F74

0x0F75

0x0F76

0x0F77

0x0F78

0x0F7F

|                            | SFR2                                                         |  |  |  |  |
|----------------------------|--------------------------------------------------------------|--|--|--|--|
| 0x0F80                     |                                                              |  |  |  |  |
|                            |                                                              |  |  |  |  |
| 0x0F8B                     | NO 3110 P                                                    |  |  |  |  |
| 0x0F8C                     | T02MOD                                                       |  |  |  |  |
| 0x0F8D                     | T03MOD<br>T023CR                                             |  |  |  |  |
| 0x0F8E<br>0x0F8F           |                                                              |  |  |  |  |
| 0x0F8F                     | TOOCNITI                                                     |  |  |  |  |
| 0x0F90                     | TOOCNTH                                                      |  |  |  |  |
| 0x0F92                     | T00CNTL<br>T00CNTH<br>T01CNTL<br>T01CNTH                     |  |  |  |  |
| 0x0F93                     | TOICNTH                                                      |  |  |  |  |
| 0x0F94                     | 1 T02CNTI I                                                  |  |  |  |  |
| 0x0F95                     | TOZENTH                                                      |  |  |  |  |
| 0x0F96                     | TORCNIT                                                      |  |  |  |  |
| 0x0F97                     | TOJCNTH                                                      |  |  |  |  |
| 0x0F98                     |                                                              |  |  |  |  |
|                            |                                                              |  |  |  |  |
| 0x0F9B                     | TOODECI                                                      |  |  |  |  |
| 0x0F9C                     | TOOREGL<br>TOOREGH                                           |  |  |  |  |
| 0x0F9D<br>0x0F9E           | TOTREGL                                                      |  |  |  |  |
| 0x0F9E<br>0x0F9F           | T01REGL                                                      |  |  |  |  |
| 0x0F9F<br>0x0FA0           | TOOPWML                                                      |  |  |  |  |
| 0x0FA1                     | TOOPWML                                                      |  |  |  |  |
| 0x0FA2                     | TOTPWML                                                      |  |  |  |  |
| 0x0FA3                     | TOTPW/MH                                                     |  |  |  |  |
| 0x0FA4                     | TOZREGL                                                      |  |  |  |  |
| 0x0FA5                     | T02REGL<br>T02REGH                                           |  |  |  |  |
| 0x0FA6                     | T03REGL<br>T03REGH                                           |  |  |  |  |
| 0x0FA7                     | T03REGH                                                      |  |  |  |  |
| 0x0FA8                     | T02PWML                                                      |  |  |  |  |
| 0x0FA9                     | T02PWMH                                                      |  |  |  |  |
| 0x0FAA                     | T03PWML                                                      |  |  |  |  |
| 0x0FAB                     | T03PWMH                                                      |  |  |  |  |
| 0x0FAC                     |                                                              |  |  |  |  |
|                            |                                                              |  |  |  |  |
| 0x0FAF                     | <b>X0 ( 0 5 5 )</b>                                          |  |  |  |  |
| 0x0FB0                     | T04REGL                                                      |  |  |  |  |
| 0x0FB1                     | TOFREGH                                                      |  |  |  |  |
| 0x0FB2<br>0x0FB3           | T04REGH<br>T05REGL<br>T05REGH                                |  |  |  |  |
| 0x0FB3                     | T04PWML                                                      |  |  |  |  |
| 0x0FB5                     | T04PWML<br>T04PWMH                                           |  |  |  |  |
| 0x0FB6                     | T05PW/MI                                                     |  |  |  |  |
| 0x0FB7                     | TO5PWMH                                                      |  |  |  |  |
| 0x0FB8                     | I T04MOD I                                                   |  |  |  |  |
| 0x0FB9                     |                                                              |  |  |  |  |
| 0x0FBA                     | T045CR                                                       |  |  |  |  |
| 0x0FBB                     | T05MOD<br>T045CR<br>T04CNTL<br>T04CNTH<br>T05CNTL<br>T05CNTH |  |  |  |  |
| 0x0FBC                     | T04CNTH                                                      |  |  |  |  |
| 0x0FBD                     | T05CNTL                                                      |  |  |  |  |
| 0x0FBE                     | T05CNTH                                                      |  |  |  |  |
| 0x0FBF                     |                                                              |  |  |  |  |
|                            |                                                              |  |  |  |  |
| 0x0FC3                     |                                                              |  |  |  |  |
| 0x0FC4                     | KWUCRO                                                       |  |  |  |  |
| 0x0FC5                     | KWUCR1                                                       |  |  |  |  |
| 0x0FC6                     | VDCR1                                                        |  |  |  |  |
| 0x0FC7<br>0x0FC8<br>0x0FC9 | VDCR1<br>VDCR2<br>RTCCR                                      |  |  |  |  |
| 0x0FC8                     | RICCR                                                        |  |  |  |  |
| 0x0FC9<br>0x0FCA           |                                                              |  |  |  |  |
| 0x0FCB                     | KWUCR2<br>KWUCR3                                             |  |  |  |  |
| 0x0FCC                     | IRSTSR                                                       |  |  |  |  |
| 0x0FCD                     | WUCCR                                                        |  |  |  |  |
| 0x0FCE                     | WUCDR                                                        |  |  |  |  |
| 0x0FCF                     | CGCR                                                         |  |  |  |  |
|                            |                                                              |  |  |  |  |
|                            |                                                              |  |  |  |  |

|        | SFR2          |
|--------|---------------|
| 0x0FD0 | FLSCR1        |
| 0x0FD1 | FLSCR2/FLSCRM |
| 0x0FD2 | FLSSTB        |
| 0x0FD3 |               |
| 0x0FD4 | WDCTR         |
| 0x0FD5 | WDCDR         |
| 0x0FD6 | WDCNT         |
| 0x0FD7 | WDST          |
| 0x0FD8 |               |
| 0x0FD9 | EINTCR2       |
| 0x0FDA | EINTCR3       |
| 0x0FDB | EINTCR4       |
| 0x0FDC | SYSCR1        |
| 0x0FDD | SYSCR2        |
| 0x0FDE | SYSCR3        |
| 0x0FDF | SYSCR4/SYSSR4 |
| 0x0FE0 | ILL           |
| 0x0FE1 | ILH           |
| 0x0FE2 | ILE           |
| 0x0FE3 | ILD           |
| 0x0FE4 |               |
|        |               |
| 0x0FEF |               |
| 0x0FF0 | ILRSL         |
| 0x0FF1 | ILRSH         |
| 0x0FF2 | ILRSE         |
| 0x0FF3 | ILRSD         |
| 0x0FF4 |               |
|        |               |
| 0x0FFF |               |
|        |               |

|        | SFR3       |
|--------|------------|
| 0x0E40 | LCDBUF00   |
| 0x0E41 | LCDBUF01   |
| 0x0E42 | LCDBUF02   |
| 0x0E43 | LCDBUF03   |
| 0x0E44 | LCDBUF04   |
| 0x0E45 | LCDBUF05   |
| 0x0E46 | LCDBUF06   |
| 0x0E47 | LCDBUF07   |
| 0x0E48 | LCDBUF08   |
| 0x0E49 | LCDBUF09   |
| 0x0E50 | LCDBUF10   |
| 0x0E51 | LCDBUF11   |
| 0.0554 |            |
| 0x0E56 |            |
| 0x0E57 | UATCNG     |
| 0x0E58 |            |
|        |            |
| 0x0E7B | LCDCD1     |
| 0x0E7C | LCDCR1     |
| 0x0E7D | LCDCR2     |
| 0x0E7E | LCDCR3     |
| 0x0E7F | LCDCR4     |
| 0x0E80 | LCDCR5     |
| 0x0E81 |            |
|        |            |
| 0x0EE6 |            |
| 0x0EE7 | ADCVRF     |
| 0x0EE8 |            |
| 0.0555 |            |
| 0x0EEC | FCCTDI     |
| 0x0EED | FSCTRL     |
| 0x0EEE |            |
|        |            |
| 0x0EF6 | VREF_CALIB |
| 0.0555 |            |
| 0x0EFF |            |

Figure 4.2 SFR1 · SFR2 · SFR3

### Page: 29/ 278

## 4.3 Operation Modes

## 4.3.1 Operation Mode Control Circuit

The operation mode control circuit starts and stops the oscillation circuits for the high-frequency and low-frequency clocks, and switches the main system clock (fm). There are three operating modes: the single-clock mode, the dual-clock mode and the STOP mode. These modes are controlled by the system control registers (SYSCR1 and SYSCR2).

Figure 4.3 shows the operating mode transition diagram.

#### 4.3.1.1 Single-clock Mode

Only the gear clock (fcgck) is used for the operation in the single-clock mode. The main system clock (fm) is generated from the gear clock (fcgck). Therefore, the machine cycle is 1/fcgck [s].

The gear clock (fcgck) is generated from the high-frequency clock (fc).

#### (a) NORMAL1 Mode

In this mode, the CPU core and the peripheral circuits operate using the gear clock (fcgck). The NORMAL1 mode becomes active after reset release.

#### (b) IDLE1 Mode

In this mode, the CPU and the watchdog timer stop and the peripheral circuits operate using the gear clock (fcgck).

The IDLE1 mode is activated by setting SYSCR2 <IDLE> to "1" in the NORMAL1 mode. When the IDLE1 mode is activated, the CPU and the watchdog timer stop. When the interrupt latch enabled by the interrupt enable register EIR becomes "1", the IDLE1 mode is released to the NORMAL1 mode.

When the IMF (interrupt master enable flag) is "1" (interrupts enabled), the operation returns normal after the interrupt processing is completed. When the IMF is "0" (interrupts disabled), the operation is restarted by the instruction that follows the IDLE1 mode activation instruction.

#### (c) IDLE0 Mode

In this mode, the CPU and the peripheral circuits stop, except the oscillation circuits and the time base timer.

In the IDLE0 mode, the peripheral circuits stop in the states when the IDLE0 mode is activated or become the same as the states when a reset is released. For operations of the peripheral circuits in the IDLE0 mode, refer to the section of each peripheral circuit. The IDLE0 mode is activated by setting SYSCR2 <TGHALT> to "1" in the NORMAL1 mode.

### Page: 30/ 278

| 汉芝电子股份有限公司            |                                      |                |
|-----------------------|--------------------------------------|----------------|
| iMQ Technology Inc.   |                                      |                |
| No. : TDDS01-M6812-EN | Name: MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

When the IDLE0 mode is activated, the CPU stops and the timing generator stops the clock supply to the peripheral circuits except the time base timer.

When the falling edge of the source clock selected at TBTCR <TBTCK> is detected, the IDLE0 mode is released, the timing generator starts the clock supply to all the peripheral circuits and the NORMAL1 mode is restored.

Note that the IDLE0 mode is activated and restarted, regardless of the setting of TBTCR <TBTEN>.

When the IDLE0 mode is activated with TBTCR <TBTEN> set at "1", the INTTBT interrupt latch is set after the NORMAL mode is restored. When the IMF is "1" and the EF5 (the individual interrupt enable flag for the time base timer) is "1", the operation returns normal after the interrupt processing is completed.

When the IMF is "0" or when the IMF is "1" and the EF5 (the individual interrupt enable flag for the time base timer) is "0", the operation is restarted by the instruction that follows the IDLE0 mode activation instruction.

## 4.3.1.2 Dual-clock Mode

The gear clock (fcgck) and the low-frequency clock (fs) are used for the operation in the dual-clock mode.

The main system clock (fm) is generated from the gear clock (fcgck) in the NORMAL2 or IDLE2 mode, and generated from the clock that is a quarter of the low-frequency clock (fs) in the SLOW1/2 or SLEEP0/1 mode. Therefore, the machine cycle time is 1/fcgck [s] in the NORMAL2 or IDLE2 mode and is 4/fs [s] in the SLOW1/2 or SLEEP0/1 mode.

The operation of the MCU core becomes the single-clock mode after reset release. To operate it in the dual-clock mode, allow the low-frequency clock to oscillate at the beginning of the program.

#### (a) NORMAL2 mode

In this mode, the CPU core operates using the gear clock (fcgck), and the peripheral circuits operate using the gear clock (fcgck) or the clock that is a quarter of the low-frequency clock (fs).

#### (b) SLOW2 mode

In this mode, the CPU core and the peripheral circuits operate using the clock that is a quarter of the low-frequency clock (fs).

In the SLOW mode, some peripheral circuits become the same as the states when a reset is released. For operations of the peripheral circuits in the SLOW mode, refer to the section of each peripheral circuit.

## Page: 31/ 278

Set SYSCR2 <SYSCK> to switch the operation mode from NORMAL2 to SLOW2 or from SLOW2 to NORMAL2.In the SLOW2 mode, outputs of the prescaler and stages 1 to 8 of the divider stop.

### (c) SLOW1 mode

In this mode, the high-frequency clock oscillation circuit stops operation and the CPU core and the peripheral circuits operate using the clock that is a quarter of the low-frequency clock (fs).

This mode requires less power to operate the high-frequency clock oscillation circuit than in the SLOW2 mode.

In the SLOW mode, some peripheral circuits become the same as the states when a reset is released. For operations of the peripheral circuits in the SLOW mode, refer to the section of each peripheral circuit.

Set SYSCR2 <XEN> to switch the operation between the SLOW1 and SLOW2 modes. In the SLOW1 or SLEEP1 mode, outputs of the prescaler and stages 1 to 8 of the divider stop.

### (d) IDLE2 mode

In this mode, the CPU and the watchdog timer stop and the peripheral circuits operate using the gear clock (fcgck) or the clock that is a quarter of the low-frequency clock (fs).

The IDLE2 mode can be activated and released in the same way as for the IDLE1 mode. The operation returns to the NORMAL2 mode after this mode is released.

#### (e) SLEEP1 mode

In this mode, the high-frequency clock oscillation circuit stops operation, the CPU and the watchdog timer stop, and the peripheral circuits operate using the clock that is a quarter of the low-frequency clock (fs).

In the SLEEP1 mode, some peripheral circuits become the same as the states when a reset is released. For operations of the peripheral circuits in the SLEEP1 mode, refer to the section of each peripheral circuit. The SLEEP1 mode can be activated and released in the same way as for the IDLE1 mode. The operation returns to the SLOW1 mode after this mode is released.

In the SLOW1 or SLEEP1 mode, outputs of the prescaler and stages 1 to 8 of the divider stop.

### (f) SLEEP0 mode

In this mode, the high-frequency clock oscillation circuit stops operation, the time base timer operates using the clock that is a quarter of the low-frequency clock (fs), and the core and the peripheral circuits stop.

## Page: 32/ 278

| 汉芝电子股份有限公司<br>iMQ Technology Inc. |                                       |                |
|-----------------------------------|---------------------------------------|----------------|
| No. : TDDS01-M6812-EN             | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

In the SLEEP0 mode, the peripheral circuits stop in the states when the SLEEP0 mode is activated or become the same as the states when a reset is released. For operations of the peripheral circuits in the SLEEP0 mode, refer to the section of each peripheral circuit. The SLEEP0 mode can be activated and released in the same way as for the IDLE0 mode. The operation returns to the SLOW1 mode after this mode is released.

In the SLEEP0 mode, the CPU stops and the timing generator stops the clock supply to the peripheral circuits except the time base timer.

## 4.3.1.3 STOP mode

In this mode, all the operations in the system including the oscillation circuits are stopped and the internal states in effect before the system was stopped are held with low power consumption.

In the STOP mode, the peripheral circuits stop in the states when the STOP mode is activated or become the same as the states when a reset is released. For operations of the peripheral circuits in the STOP mode, refer to the section of each peripheral circuit. The STOP mode is activated by setting SYSCR1 <STOP> to "1".

The STOP mode is released by the STOP mode release signals. After the warm-up time has elapsed, the operation returns to the mode that was active before the STOP mode, and the operation is restarted by the instruction that follows the STOP mode activation instruction.

## 4.3.1.4 Transition of Operation Modes



Figure 4.3 Operation Mode Transition Diagram

Page: 33/ 278

## 汉芝电子股份有限公司 iMO Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Operation mode  |         | Oscillation circuit |                  | CDU                                      | WOT                                          | TDT     | Other                 | Machine          |
|-----------------|---------|---------------------|------------------|------------------------------------------|----------------------------------------------|---------|-----------------------|------------------|
|                 |         | High<br>frequency   | Low<br>frequency | CPU                                      | WDT                                          | TBT     | peripheral<br>ciruits | cycle time       |
| Single<br>clock | RESET   | - Oscillation       | Stop             | Reset                                    | Reset                                        | Reset   | Reset                 | 1/fcgck          |
|                 | Normal1 |                     |                  | Operate                                  | Operate                                      |         | <b>0</b>              |                  |
|                 | IDLE1   |                     |                  | Stop Stop                                | Operate                                      | Operate | (sec)                 |                  |
|                 | IDLE0   |                     |                  |                                          | Stop                                         |         | Stop                  |                  |
|                 | STOP    | Stop                |                  |                                          |                                              | Stop    |                       |                  |
| Dual<br>clock   | Normal2 |                     | Oscillation      | Operate<br>with the<br>high<br>frequency | Operate<br>with the<br>high/low<br>frequency | Operate | Operate               | 1/fcgck<br>(sec) |
|                 | IDLE2   | Oscillation         |                  | Stop                                     | Stop                                         |         |                       |                  |
|                 | SLOW2   |                     |                  | Operate<br>with the<br>low<br>frequency  | Operate<br>with the<br>low<br>frequency      |         |                       | 4/fs<br>(sec)    |
|                 | SLOW1   |                     |                  | Operate<br>with the<br>low<br>frequency  | Operate<br>with the<br>low<br>frequency      |         |                       |                  |
|                 | SLEEP1  | Stop                | Stop<br>Stop     | Stop                                     | Stop                                         |         |                       |                  |
|                 | SLEEPO  |                     |                  |                                          |                                              |         | Stop                  |                  |
|                 | STOP    |                     |                  |                                          |                                              | Stop    |                       |                  |

#### Table 4.1 Operation Modes and Conditions

Note 1): The NORMAL1 and NORMAL2 modes are generically called the NORMAL mode; the SLOW1 and SLOW2 modes are called the SLOW mode; the IDLE0, IDLE1 and IDLE2 modes are called the IDLE mode; and the SLEEP0 and SLEEP1 are called the SLEEP mode.

Note 2]: The mode is released by the falling edge of the source clock selected at TBTCR <TBTCK>.

## 4.3.2 Operation Mode Control

### 4.3.2.1 STOP Mode

The STOP mode is controlled by system control register 1 (SYSCR1) and the STOP mode release signals.

#### (a) Start the STOP Mode

The STOP mode is started by setting SYSCR1<STOP> to "1". In the STOP mode, the following states are maintained:

- 1. Both the high-frequency and low-frequency clock oscillation circuits stop oscillation and all internal operations are stopped.
- 2. The data memory, the registers and the program status word are all held in the states in effect before STOP mode was started. The port output latch is determined by the value

## Page: 34 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

of SYSCR1 <OUTEN>.

- 3. The prescaler and the divider of the timing generator are cleared to "0".
- 4. The program counter holds the address of the instruction 2 ahead of the instruction (e.g., [SET (SYSCR1).7]) which started the STOP mode.

### (b) Release the STOP Mode

The STOP mode is released by the following STOP mode release signals. It is also released by a reset by the RESETB pin, a power-on reset and a reset by the voltage detection circuits. When a reset is released, the warm-up starts. After the warm-up is completed, the NORMAL1 mode becomes active.

- 1. Release by the STOPB pin
- 2. Release by key-on wakeup
- 3. Release by the voltage detection circuits

Note): During the STOP period (from the start of the STOP mode to the end of the warm-up), due to changes in the external interrupt pin signal, interrupt latches may be set to "1" and interrupts may be accepted immediately after the STOP mode is released. Before starting the STOP mode, therefore, disable interrupts. Also, before enabling interrupts after STOP mode is released, clear unnecessary interrupt latches.

#### 1. Release by the STOPB pin

Release the STOP mode by using the STOPB pin.

To release the STOP mode by using the STOPB pin, set VDCR2 <VDSS> to "00" or "10". (For details of VDCR2, refer to "5.3 Voltage Detection Circuits")

The STOP mode released by the STOPB pin includes the level-sensitive release mode and the edge-sensitive release mode, either of which can be selected at SYSCR1 <RELM>.

The STOPB pin is also used as the P11 and the INT5B (external interrupt input 5) pin.

### • Level-sensitive release mode

The STOPB mode is released by setting the STOPB pin high.

Setting SYSCR1 <RELM> to "1" selects the level-sensitive release mode.

This mode is used for the capacitor backup when the main power supply is cut off and the long term battery backup.

Even if an instruction for starting the STOP mode is executed while the STOPB pin input is high, the STOP mode does not start. Thus, to start the STOP mode in the level- release mode, it is necessary for the program to first confirm that the STOPB

## Page: 35 / 278

pin input is low. This can be confirmed by testing the port by the software or using interrupt.

### • Edge-sensitive release mode

In this mode, the STOP mode is released at the rising edge of the STOP pin input. Setting SYSCR1 <RELM> to "0" selects the edge-sensitive release mode.

This is used in applications where a relatively short program is executed repeatedly at periodic intervals. This periodic signal (such as a clock from a low-power consumption oscillator) is input to the STOPB pin. In the edge-sensitive release mode, the STOP mode is started even when the STOPB pin input is high.

#### 2. Release by the Key-on Wakeup

The STOP mode is released by inputting the prescribed level to the key-on wakeup pin. The level to release the STOP mode can be selected from "H" and "L". For release by the key-on wakeup, refer to "3.7 Key-on Wakeup" in iMQ i87 User Manual.

Note): If the key-on wakeup pin input becomes the opposite level to the release level after the warm-up starts, the STOP mode is not restarted.

#### 3. Release by the Voltage Detection Circuits

The STOP mode is released by the supply voltage detection by the voltage detection circuits. To release the STOP mode by using the voltage detection circuits, set VDCR2 <VDSS> to "01" or "10". If the voltage detection operation mode of the voltage detection circuits is set to generate reset signals (when VDCR2 <VDxMOD> is 1 (x=1 to 2)), the STOP mode is re-leased and a reset is applied as soon as the supply voltage becomes lower than the detection voltage.

When the supply voltage becomes equal to or higher than the detection voltage of the voltage detection circuits, the reset is released and the warm-up starts. After the warm-up is completed, the NORMAL1 mode becomes active.

If the voltage detection operation mode of the voltage detection circuits is set to generate interrupt request signals (when VDCR2 <VDxMOD> is 0 (x=1 to 2)), the STOP mode is released when the supply voltage becomes equal to or higher than the detection voltage. For details, refer to the section of the voltage detection circuits.

Note): If the supply voltage becomes equal to or higher than the detection voltage within 1 machine cycle after SYSCR1 <STOP> is set to "1", the STOP mode will not be released.

#### (c) STOP Mode Release Operation

## Page: 36 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

| Operation mode before the STOP<br>mode is started |         | High-frequency<br>clock                        | Low-frequency<br>clock                          | Oscillation start operation after release                                                                                                 |
|---------------------------------------------------|---------|------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Single-clock<br>mode                              | NORMAL1 | High-frequency<br>clock oscillation<br>circuit | -                                               | The high-frequency clock oscillation circuit starts<br>oscillation.<br>The low-frequency clock oscillation circuit stops<br>oscillation.  |
| Dual alash mada                                   | NORMAL2 | High-frequency<br>clock oscillation<br>circuit | Low-frequency<br>clock oscillation cir-<br>cuit | The high-frequency clock oscillation circuit starts<br>oscillation.<br>The low-frequency clock oscillation circuit starts<br>oscillation. |
| Dual-clock mode                                   | SLOW1   | -                                              | Low-frequency<br>clock oscillation cir-<br>cuit | The high-frequency clock oscillation circuit stops<br>oscillation.<br>The low-frequency clock oscillation circuit starts<br>oscillation.  |

Table 4.2 Oscillation Start Operation at Release of the STOP Mode

Note): When the operation returns to the NORMAL2 mode, fc is input to the frequency division circuit of the warmup counter.

The STOP mode is released in the following sequence:

- 1. Oscillation starts. For the oscillation start operation in each mode, refer to "Table 4.2 Oscillation Start Operation at Release of the STOP Mode".
- 2. Warm-up is executed to secure the time required to stabilize oscillation. The internal operations remain stopped during warm-up. The warm-up time is set by the warm-up counter, depending on the oscillator characteristics.
- 3. After the warm-up time has elapsed, the normal operation is restarted by the instruction that follows the STOP mode start instruction. At this time, the prescaler and the divider of the timing generator are cleared to "0".

Note): When the STOP mode is released with a low hold voltage, the following cautions must be observed. The supply voltage must be at the operating voltage level before releasing the STOP mode. The RESETB pin input must also be "H" level, rising together with the supply voltage. In this case, if an external time constant circuit has been connected, the RESETB pin input voltage will increase at a slower pace than the power supply voltage. At this time, there is a danger that a reset may occur if the input voltage level of the RESETB pin drops below the non-inverting high-level input voltage (Hysteresis input).

## Page: 37 / 278





Reset input

Figure 4.4 IDLE 1/2 and SLEEP1 Modes

The IDLE1/2 and SLEEP1 modes are controlled by the system control register 2 (SYSCR2) and maskable interrupts. The following states are maintained during these modes.

1. The CPU and the watchdog timer stop their operations. The peripheral circuits continue to operate.

Yes

Reset

- 2. The data memory, the registers, the program status word and the port output latches are all held in the status in effect before IDLE1/2 or SLEEP1 mode was started.
- 3. The program counter holds the address of the instruction 2 ahead of the instruction which starts the IDLE1/2 or SLEEP1 mode.

### (a) Start the IDLE 1/2 and SLEEP1 Modes

After the interrupt master enable flag (IMF) is set to "0", set the individual interrupt enable flag (EF) to "1", which releases IDLE1/2 and SLEEP1 modes. To start the IDLE1/2 or SLEEP1 mode, set SYSCR2 <IDLE> to "1". If the release condition is satisfied when it is attempted to start the IDLE1/2 or SLEEP1 mode, SYSCR2 <IDLE> remains cleared and the IDLE1/2 or SLEEP1 mode will not be started.

Note 1): When a watchdog timer interrupt is generated immediately before the IDLE1/2 or SLEEP1 mode is started, the watchdog timer interrupt will be processed but the IDLE1/2 or SLEEP1 mode will not be started. Note 2): Before starting the IDLE1/2 or SLEEP1 mode, enable the interrupt request signals to be generated to release

# Page: 38/ 278

the IDLE1/2 or SLEEP1 mode and set the individual interrupt enable flag.

#### (b) Release the IDLE1/2 and SLEEP1 Modes

The IDLE1/2 and SLEEP1 modes include a normal release mode and an interrupt release mode. These modes are selected at the interrupt master enable flag (IMF). After releasing IDLE1/2 or SLEEP1 mode, SYSCR2 <IDLE> is automatically cleared to "0" and the operation mode is returned to the mode preceding the IDLE1/2 or SLEEP1 mode.

The IDLE 1/2 and SLEEP1 modes are also released by a reset by the RESETB pin, a power-on reset and a reset by the voltage detection circuits. After releasing the reset, the warm-up starts. After the warm-up is completed, the NORMAL1 mode becomes active.

### 1. Normal release mode (IMF = "0")

The IDLE1/2 or SLEEP1 mode is released when the interrupt latch enabled by the individual interrupt enable flag (EF) is "1". The operation is restarted by the instruction that follows the IDLE1/2 or SLEEP1 mode start instruction. Normally, the interrupt latch (IL) of the interrupt source used for releasing must be cleared to "0" by load instructions.

#### 2. Interrupt release mode (IMF = "1")

The IDLE1/2 or SLEEP1 mode is released when the interrupt latch enabled by the individual interrupt enable flag (EF) is "1". After the interrupt is processed, the operation is restarted by the instruction that follows the IDLE1/2 or SLEEP1 mode start instruction.

iMQ reserves the right to change the information in this document without prior notice. Please contact iMQ to obtain the latest version of product specification before placing your order. Use of iMQ devices in life support is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless iMQ from any and all damages, claims, suits or expenses resulting from such use.

## Page: 39/ 278



# Figure 4.5 IDLE0 and SLEEP0 Modes

SLEEP0 mode start instruction

The IDLE0 and SLEEP0 modes are controlled by the system control register 2 (SYSCR2) and the time base timer control register (TBTCR). The following states are maintained during the IDLE0 and SLEEP0 modes:

- 1. The timing generator stops the clock supply to the peripheral circuits except the time base timer.
- 2. The data memory, the registers, the program status word and the port output latches are all held in the states in effect before the IDLE0 or SLEEP0 mode was started.
- 3. The program counter holds the address of the instruction 2 ahead of the instruction which starts the IDLE0 or SLEEP0 mode.

#### (a) Start the IDLE0 and SLEEP0 Modes

Stop (disable) the peripherals such as a timer counter. To start the IDLE0 or SLEEP0 mode, set SYSCR2 <TGHALT> to "1".

## Page: 40 / 278

#### (b) Release the IDLE0 and SLEEP0 Modes

The IDLE0 and SLEEP0 modes include a normal release mode and an interrupt release mode. These modes are selected at the interrupt master enable flag (IMF), the individual interrupt enable flag (EF5) for the time base timer and TBTCR <TBTEN>. After releasing the IDLE0or SLEEP0 mode, SYSCR2 <TGHALT> is automatically cleared to "0" and the operation mode is returned to the mode preceding the IDLE0 or SLEEP0 mode. If TBTCR <TBTEN>has been set at "1", the INTTBT interrupt latch is set.

The IDLE0 and SLEEP0 modes are also released by a reset by the RESETB pin, a power-on reset and a reset by the voltage detection circuits. When a reset is released, the warm-up starts. After the warm-up is completed, the NORMAL1 mode becomes active.

#### 1. Normal Release Mode (IMF, EF5, TBTCR<TBTEN> = "0")

The IDLE0 or SLEEP0 mode is released when the falling edge of the source clock selected at TBTCR <TBTCK> is detected. After the IDLE0 or SLEEP0 mode is released, the operation is restarted by the instruction that follows the IDLE0 or SLEEP0 mode start instruction.

When TBTCR <TBTEN> is "1", the time base timer interrupt latch is set.

#### 2. Interrupt Release Mode (IMF, EF5, TBTCR<TBTEN> = "1")

The IDLE0 or SLEEP0 mode is released when the falling edge of the source clock selected at TBTCR <TBTCK> is detected. After the release, the INTTBT interrupt processing is started.

Note 1/: The IDLEO or SLEEPO mode is released to the NORMAL1 or SLOW1 mode by the asynchronous internal clock selected at TBTCR <TBTCK>. Therefore, the period from the start to the release of the mode may be shorter than the time specified at TBTCR <TBTCK>.

Note 2]: When a watchdog timer interrupt is generated immediately before the IDLE0 or SLEEP0 mode is started, the watchdog timer interrupt will be processed but the IDLE0 or SLEEP0 mode will not be started.

#### 4.3.2.4 SLOW Mode

The SLOW mode is controlled by system control register 2 (SYSCR2).

(a) Switching from the NORMAL2 Mode to the SLOW1 Mode Set SYSCR2 <SYSCK> to "1".

When a maximum of 2/fcgck + 10/fs [s] has elapsed since SYSCR2 <SYSCK> is set to "1", the main system clock (fm) is switched to fs/4. After switching, wait for 2 machine cycles or longer,

## Page: 41/ 278



SYSCR2<SYSCK>

When the rising edge of fs/4 is detected twice after SYSCR2 <SYSCK> is changed from 1 to 0, fm is stopped for synchronization.
 When the rising edge of fs/4 is detected twice after fm is stopped, fm is switched to fs.



#### (b) Switching from the SLOW1 Mode to the NORMAL1 Mode

Main system clock

Set SYSCR2 <XEN> to "1" to enable the high-frequency clock (fc) to oscillate. Confirm at the warm-up counter that the oscillation of the basic clock for the high-frequency clock has stabilized, and then clear SYSCR2 <SYSCK> to "0".

10/fs (max.)

When a maximum of 8/fs + 2.5/fcgck [s] has elapsed since SYSCR2 <SYSCK> is cleared to"0", the main system clock (fm) is switched to fcgck. After switching, wait for 2 machine cycles or longer, and then clear SYSCR2 <XTEN> to "0" to turn off the low-frequency clock oscillator.

The SLOW mode is also released by a reset by the RESETB pin, a power-on reset and a reset by the voltage detection circuits. When a reset is released, the warm-up starts. After the warm-up is completed, the NORMAL1 mode becomes active.



Page: 42 / 278

Note 2): After switching SYSCR2 <SYSCK>, be sure to wait for 2 machine cycles or longer before clearing SYSCR2 <XTEN> to "0". Clearing it within 2 machine cycles causes a system clock reset.

Note 3):When the main system clock (fm) is switched, the gear clock (fcgck) is synchronized with the clock that is a quarter of the basic clock (fs) for the low-frequency clock. For the synchronization, fm is stopped for a period of 2.5/fcgck [s] or shorter.

Note 4]: When P0FC0 is "0", setting SYSCR2 <XEN> to "1" causes a system clock reset.

*Note 5): When SYSCR2 <XEN> is set at "1", writing "1" to SYSCR2 <XEN> does not cause the warm-up counter to start counting the source clock.* 

# 4.4 Stack Area and Stack Pointer

# 4.4.1 Stack Area

A stack is an area in memory for temporarily saving the PC, PSW and other values during subroutines and interrupts.

When a subroutine is called by the [CALL mn] or [CALLV n] instruction, the CPU pushes (saves) the high-order and low-order bytes of the return address on the stack before jumping to the subroutine entry address. When the software interrupt instruction, SWI, is executed and when a hardware interrupt is accepted, the CPU saves the PSW and then return address on the stack.

When the return-from-subroutine instruction, RET, is executed, the CPU pops (restores) the return address into the PC. When the return-from-interrupt instruction, RETI or RETN, is executed, the CPU restores the PC and PSW from the stack.

A stack can be allocated anywhere in the data area.

# 4.4.2 Stack Pointer

The Stack Pointer (SP) is a 16-bit register that holds the address of the next available location on the stack. The SP is post-decremented on subroutine calls, PUSH operations and interrupts, and preincremented on returns from subroutines and interrupts and POP operations. The stack grows downwards from high addresses to low addresses as it is filled.

|   | SP      |               |
|---|---------|---------------|
| ← | 16 bits | $\rightarrow$ |



### Page: 43/ 278

Figure 4.9 shows the contents of the stack and the SP register as each of the following instructions is executed.

The SP register defaults to 0x00FF upon hardware reset.

Like an index register, the SP register can be modified by using load / store and ALU instructions. The SP register can also be used as an index register in Indexed Addressing.



(a) PC and PSW in the stack (Pushing and popping)



(b) Direction in which the stack grows



# 4.5 Program Counter (PC)

# 4.5.1 Program Counter - PC

The Program Counter (PC) is an 8-bit register that holds the address of next instruction to be executed in the code area. When the reset signal is released, the CPU loads the reset vector stored in the vector table (at 0xFFFF and 0xFFFE in MCU mode) into the PC; thus the program can start at an arbitrary address. The iMO i87 Series is pipelined; that is, CPU instructions are pre-fetched. Therefore, the PC points to an address two bytes after the address of the instruction being executed. For example, the PC contains 0xC125 while the single-byte instruction stored at 0xC123 is being

# Page: 44 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

#### executed.



Figure 4.10 Program Counter

# 4.5.2 Effects of Jump Instructions on the PC Value

There are relative and absolute jump instructions. The jump destination is limited within the code area; a jump cannot occur to the data area. The following describes the effects of jump instructions on the PC value.

## (1) Relative Jump Instruction with a 5-bit Displacement (JRS cc, +2 + d)

When the memory location at 0xE8C4 contains the instruction "JRS T, \$ + 2 + 0x08", if JF = 1, the PC is incremented by 0x08; i.e., a jump occurs to the address 0xE8CE. (The PC points to an address two bytes after the address of the instruction being executed. In this example, the PC contains 0xE8C4 + 2 = 0xE8C6 before the jump.)

(2) Relative Jump Instructions with an 8-bit Displacement (JR cc, \$ + 2 + d / JR cc, \$ + 3 + d) When the memory location at 0xE8C4 contains the instruction "JR Z, \$ + 2 + 0x80", if ZF = 1, a jump occurs to an address that is calculated by PC + 0xFF80 (-128). Thus the jump destination is 0xE846.

### (3) 16-bit Absolute Jump Instruction (JP a)

When the memory location at 0xE8C4 contains the instruction "JP 0xC235", a jump occurs unconditionally to the address 0xC235. The absolute jump instruction can jump to a location within the full range of the code area (therefore, 8K Bytes for MQ6812/MQ6821).

# 4.6 General-Purpose Register

MQ6812/MQ6821 has eight 8-bit general-purpose registers called W, A, B, C, D, E, H and L. These registers can be used as 16-bit register pairs called WA, BC, DE and HL.

The general-purpose registers are not mapped to the address space. The contents of the general-purpose registers are undefined after power-up and reset.

# Page: 45/ 278



Figure 4.11 General-Purpose Registers

The W, A, B, C, D, E, H and L registers are individually used by the 8-bit load/store and ALU instructions.

The WA, BC, DE and HL register pairs are used by the 16-bit load/store and ALU instructions. These registers also provide the functionalities discussed in the following subsections in addition to the common characteristics as general-purpose registers.

# 4.6.1 A Registers

Bit manipulation instructions can use the A register to specify a bit position in a register whose value should be tested or changed.

The A register is also used as an offset register in PC-Relative Register Indirect Addressing (PC + A).

# 4.6.2 C Registers

For divide instructions, the C register holds the divisor. The remainder is written back into the upper byte of the register pair specified as the dividend; the quotient is written back into the lower byte.

The C register is also used as an offset register in Register Indexed Addressing (HL + C).

# 4.6.3 DE Registers

In Register Indirect Addressing, the DE register holds the address of the memory location where the operand resides.

# Page: 46 / 278

# 4.6.4 HL Registers

In Register Indirect Addressing, the HL register holds the address of the memory location where the operand resides. In Indexed Addressing, the HL register is used as an index register.

# 4.6.5 16-Bit General-Purpose Registers (IX, IY)

MQ6812/MQ6821 has two 16-bit general-purpose registers called IX and IY. In Register Indirect Addressing, these registers hold the address of the memory location where the operand resides. In Indexed Addressing, they are used as index registers.

The contents of the IX and IY registers are undefined after power-up and reset.



Figure 4.12 16-Bit General-Purpose Registers

The load/store and ALU instructions can also use the IX and IY registers as 16-bit general-purpose registers.

# 4.7 Program Status Word (PSW)

The Program Status Word, which resides at address 0x003F in the SFR, consists of the following seven flags:

- Jump Status Flag (JF)
- Zero Flag (ZF)
- Carry Flag (CF)
- Half Carry Flag (HF)
- Sign Flag (SF)
- Overflow Flag (VF)

Dedicated instructions are available to access the PSW. General load instructions can also be used to read the PSW.

Organization of the PSW

| PSW      | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
|----------|----|----|----|----|----|----|---|---|
| (0x003F) | JF | ZF | CF | HF | SF | VF | - | - |

# Page: 47 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

The PSW consists of seven bits of status information that are set or cleared by CPU operations. The flags can be specified as a condition code (cc) in conditional jump instructions, "JR cc, a" and "JRS cc, a", exceptHF.

| сс  | Meaning                           | Condition                  |
|-----|-----------------------------------|----------------------------|
| Т   | True                              | JF = 1                     |
| F   | False                             | JF = 0                     |
| Z   | Zero                              | ZF = 1                     |
| NZ  | Not zero                          | ZF = 0                     |
| CS  | Carry set                         | CF = 1                     |
| CC  | Carry clear                       | CF = 0                     |
| VS  | Overflow set                      | VF = 1                     |
| VC  | Overflow clear                    | VF = 0                     |
| м   | Minus                             | SF = 1                     |
| Р   | Plus                              | SF = 0                     |
| EQ  | Equal                             | ZF = 1                     |
| NE  | Not equal                         | ZF = 0                     |
| LT  | Unsigned less than                | CF = 1                     |
| GE  | Unsigned greater than or equal to | CF = 0                     |
| LE  | Unsigned less than or equal to    | (CF v ZF) = 1              |
| GT  | Unsigned greater than             | (CF v ZF) = 0              |
| SLT | Signed less than                  | (SFv VF) = 1               |
| SGE | Signed greater than or equal to   | (SFv VF) = 0               |
| SLE | Signed less than or equal to      | ZF v (SF v VF) = 1         |
| SGT | Signed greater than               | $ZF \vee (SF \vee VF) = 0$ |

### Table 4.3 Condition Code (cc) Table

The instruction "LD PSWclears all the other bits in the PSW.

An attempt to write to the address 0x3F using a load instruction is ignored. Instead, the PSW bits are set or cleared, as predefined for a given instruction.

Upon an interrupt, the PSW is pushed (saved) onto the stack, together with the Program Counter. The content of the stack is popped (restored) to the PSW by the return-from-interrupt instructions, RETI and RETN.

The values of the PSW bits become undefined upon power-up and reset.

# 4.7.1 Zero Flag (ZF)

The ZF bit is set to 1 when the result of the last ALU instruction or the operand of the last load/store instruction is 0x00 (for 8-bit ALU or load/store operations) or 0x0000 (for 16-bit ALU operations). The ZF bit is also set to 1 when the value of the bit specified by the last bit manipulation instruction

# Page: 48/ 278

is zero; otherwise, the ZF bit is cleared to 0. Also, the ZF bit is set when the high-order eight bits of the product of the last multiply instruction or the remainder of the last divide instruction is 0x00; otherwise, the ZF bit is cleared to 0.

# 4.7.2 Carry Flag (CF)

The CF bit contains a carry from an addition or a borrow as a result of subtraction. The CF bit is also set to 1 when the divisor of the last divide instruction is 0x00 (divided-by-zero error) or the quotient is equal to or greater than 0x100 (quotient overflow error). Shift and rotate instructions operate with and through the CF bit. For bit manipulation instructions, the CF bit serves as a single-bit Boolean accumulator. The CF bit can be set, cleared and complemented via instructions.

# 4.7.3 Half Carry Flag (HF)

The HF bit contains a carry to bit 4 or a borrow from bit 4 as a result of an 8-bit addition or subtraction. The HF bit is used for binary-coded decimal (BCD) addition / subtraction and correction, DAA r and DASr.

# 4.7.4 Sign Flag (SF)

The SF bit is set to 1 when the most significant bit (MSB) of the result of the last arithmetic operation is one. Otherwise, the SF bit is cleared to 0.

# 4.7.5 Overflow Flag (VF)

The VF bit is set to 1 when there is an overflow as a result of an arithmetic operation. Otherwise, the VF bit is cleared to 0. For example, the VF bit is set when adding two positive numbers gives a negative result or when adding two negative numbers gives a positive result.

# 4.7.6 Jump Status Flag (JF)

The JF bit is usually set to 1, and is cleared to 0 or hold a carry according to a specific instruction. The JF bit is used as a condition for conditional jump instructions, "JR T/F, a" and "JRS T/F, a" (where T and F represent true and false condition codes).

# Page: 49/ 278

#### Example: The assumptions are:

WA register = 0x219AHL register = 0x00C5Data Memory location at 0x000C5 = 0xD7CF = 1, HF = 0, SF = 1, VF = 0

The following table shows how the A and WA registers and the PSW bits are affected by various instructions.

| Instruction    | Result in |    |    | PS | SW |    |    |
|----------------|-----------|----|----|----|----|----|----|
| instruction    | A or WA   | JF | ZF | CF | HF | SF | VF |
| ADDC A, (HL)   | 72        | 1  | 0  | 1  | 1  | 0  | 1  |
| SUBB A, (HL)   | C2        | 1  | 0  | 1  | 0  | 1  | 0  |
| CMP A, (HL)    | 9A        | 0  | 0  | 1  | 0  | 1  | 0  |
| AND A, (HL)    | 92        | 0  | 0  | 1  | 0  | 1  | 0  |
| LD A, (HL)     | D7        | 1  | 0  | 1  | 0  | 1  | 0  |
| ADD A, 0x66    | 00        | 1  | 1  | 1  | 1  | 0  | 0  |
| INC A          | 9B        | 0  | 0  | 1  | 0  | 1  | 0  |
| ROLC A         | 35        | 1  | 0  | 1  | 0  | 1  | 0  |
| RORC A         | CD        | 0  | 0  | 0  | 0  | 1  | 0  |
| ADD WA, 0xF508 | 16A2      | 1  | 0  | 1  | 0  | 0  | 0  |
| MUL WA         | 13DA      | 0  | 0  | 1  | 0  | 1  | 0  |
| SET A.5        | BA        | 1  | 1  | 1  | 0  | 1  | 0  |

Table 4.4 Examples of How A and WA Registers, and the PSW Bits Affected by Various Instructions

# 4.8 Low Power Consumption Function for Peripherals

MQ6812/MQ6821 has low power consumption registers (POFFCRn) that save power when specific peripheral functions are unused. Each bit of the low power consumption registers can be set to enable or disable each peripheral function. (n = 0, 1, 2, 3)

The basic clock supply to each peripheral function is disabled for power saving, by setting the corresponding bit of the low power consumption registers (POFFCRn) to "0". (The disabled peripheral functions become unavailable.) The basic clock supply to each peripheral function is enabled and the function becomes available by setting the corresponding bit of the low power consumption registers (POFFCRn) to "1".

After reset, the low power consumption registers (POFFCRn) are initialized to "0", and thus the peripheral functions are unavailable. When each peripheral function is used for the first time, be sure to set the corresponding bit of the low power consumption registers (POFFCRn) to "1" in the initial settings of the program (before operating the control register for the peripheral function).

When a peripheral function is operating, the corresponding bit of the low power consumption registers

# Page: 50 / 278

# 汉芝电子股份有限公司 iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version : V1.1

(POFFCRn) must not be changed to "0". If it is changed, the peripheral function may operate unexpectedly.

#### Low Power Consumption Register 0

| POFFCR0<br>(0x0F74) | 7 | 6       | 5       | 4       | 3 | 2 | 1 | 0      |
|---------------------|---|---------|---------|---------|---|---|---|--------|
| Bit Symbol          | - | TC045EN | TC023EN | TC001EN | - | - | - | TCA0EN |
| Read/Write          | R | R/W     | R/W     | R/W     | R | R | R | R/W    |
| After reset         | 0 | 0       | 0       | 0       | 0 | 0 | 0 | 0      |

| TC023EN | TC04, 05 enable control | 0: Disable<br>1: Enable |
|---------|-------------------------|-------------------------|
| TC023EN | TC02, 03 enable control | 0: Disable<br>1: Enable |
| TC001EN | TC00, 01 enable control | 0: Disable<br>1: Enable |
| TCA0EN  | TCA0 enable control     | 0: Disable<br>1: Enable |

#### Low Power Consumption Register 1

| POFFCR1<br>(0x0F75) | 7 | 6 | 5 | 4      | з | 2 | 1       | 0 |
|---------------------|---|---|---|--------|---|---|---------|---|
| Bit Symbol          | - | - | - | SBIOEN | - | - | UART1EN | - |
| Read/Write          | R | R | R | R/W    | R | R | R/W     | R |
| After reset         | 0 | 0 | 0 | 0      | 0 | 0 | 0       | 0 |

| SBIOEN  | I2C0 control  | 0: Disable<br>1: Enable |
|---------|---------------|-------------------------|
| UART1EN | UART1 control | 0: Disable<br>1: Enable |

#### Low Power Consumption Register 2

| POFFCR2<br>(0x0F76) | 7     | 6 | 5     | 4 | 3 | 2 | 1 | 0             |
|---------------------|-------|---|-------|---|---|---|---|---------------|
| Bit Symbol          | LCDEN | - | RTCEN | - | - | - | - | <b>SIO0EN</b> |
| Read/Write          | R/W   | R | R/W   | R | R | R | R | R/W           |
| After reset         | 0     | 0 | 0     | 0 | 0 | 0 | 0 | 0             |

| LCDEN  | LCD enable control | 0: Disable<br>1: Enable |
|--------|--------------------|-------------------------|
| RTCEN  | RTC enable control | 0: Disable<br>1: Enable |
| sio0en | SIO0 control       | 0: Disable<br>1: Enable |

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## Low Power Consumption Register 3

| POFFCR3<br>(0x0F77) | 7   | 6   | 5   | 4      | 3      | 2      | 1   | 0   |
|---------------------|-----|-----|-----|--------|--------|--------|-----|-----|
| Bit Symbol          | -   | -   | -   | INT4EN | INT3EN | INT2EN | -   | -   |
| Read/Write          | R/W | R/W | R/W | R/W    | R/W    | R/W    | R/W | R/W |
| After reset         | 0   | 0   | 0   | 0      | 0      | 0      | 0   | 0   |

| INT4EN | INT4 Control | 0: Disable<br>1: Enable |
|--------|--------------|-------------------------|
| INT3EN | INT3 Control | 0: Disable<br>1: Enable |
| INT2EN | INT2 Control | 0: Disable<br>1: Enable |

# 4.9 Key-on Wakeup (KWU)

The key-on wakeup is a function for releasing the STOP mode at pins KWI7 through KWI2.

### 4.9.1 Configuration



#### Page: 52 / 278

# 4.9.2 Control

Key-on wakeup control registers (KWUCR0 and KWUCR1) can be configured to designate the keyon wakeup pins (KWI7 through KWI2) as STOP mode release pins and to specify the STOP mode release levels of each of these designated pins.

| KWUCR0<br>(0x0FC4) | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit Symbol         | KW3LE | KW3EN | KW2LE | KW2EN | KW1LE | KW1EN | KWOLE | KW0EN |
| Read/Write         | R/W   |
| After reset        | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

# Keyron Wakeup Control Register 0

| KW3LE                            | STOP mode release level of KWI3 pin                                                                                                                                    | 0: Low level<br>1: High level                                                                                                                       |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| KW3EN                            | Input enable / disable control of KWI3 pin                                                                                                                             | 0: Disable<br>1: Enable                                                                                                                             |
| KW2LE                            | STOP mode release level of KWI2 pin                                                                                                                                    | 0: Low level<br>1: High level                                                                                                                       |
| KW2EN                            | Input enable / disable control of KWI2 pin                                                                                                                             | 0: Disable<br>1: Enable                                                                                                                             |
| KW1LE                            | STOP mode release level of KWI 1 pin                                                                                                                                   | 0: Low level<br>1: High level                                                                                                                       |
| KW1EN                            | Input enable / disable control of KWI1 pin                                                                                                                             | 0: Disable<br>1: Enable                                                                                                                             |
| KWOLE                            | STOP mode release level of KWI0 pin                                                                                                                                    | 0: Low level<br>1: High level                                                                                                                       |
| KWOEN                            | Input enable / disable control of KWI0 pin                                                                                                                             | 0: Disable<br>1: Enable                                                                                                                             |
| KW2EN<br>KW1LE<br>KW1EN<br>KW0LE | Input enable / disable control of KWI2 pin<br>STOP mode release level of KWI1 pin<br>Input enable / disable control of KWI1 pin<br>STOP mode release level of KWI0 pin | 1: High level<br>0: Disable<br>1: Enable<br>0: Low level<br>1: High level<br>0: Disable<br>1: Enable<br>0: Low level<br>1: High level<br>0: Disable |

#### Key-on Wakeup Control Register 1

| KWUCR1<br>(0x0FC5) | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit Symbol         | KW7LE | KW7EN | KW6LE | KW6EN | KW5LE | KW5EN | KW4LE | KW4EN |
| Read/Write         | R/W   |
| After reset        | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| KW7LE | STOP mode release level of KWI7 pin        | 0: Low level<br>1: High level |
|-------|--------------------------------------------|-------------------------------|
| KW7EN | Input enable / disable control of KWI7 pin | 0: Disable<br>1: Enable       |
| KW6LE | STOP mode release level of KWI6 pin        | 0: Low level<br>1: High level |
| KW6EN | Input enable / disable control of KWI6 pin | 0: Disable<br>1: Enable       |
| KW5LE | STOP mode release level of KWI5 pin        | 0: Low level<br>1: High level |
| KW5EN | Input enable / disable control of KWI5 pin | 0: Disable<br>1: Enable       |

# 汉芝电子股份有限公司 iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| KW4LE | STOP mode release level of KWI4 pin        | 0: Low level<br>1: High level |
|-------|--------------------------------------------|-------------------------------|
| KW4EN | Input enable / disable control of KWI4 pin | 0: Disable<br>1: Enable       |

#### Key-on Wakeup Control Register 2

| KWUCR0<br>(0x0FCA) | 7      | 6      | 5      | 4      | 3     | 2     | 1     | 0      |
|--------------------|--------|--------|--------|--------|-------|-------|-------|--------|
| Bit Symbol         | KW11LE | KW11EN | KW10LE | KW10EN | KW9LE | KW9EN | KW8LE | KW/8EN |
| Read/Write         | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   | R/W   | R/W    |
| After reset        | 0      | 0      | 0      | 0      | 0     | 0     | 0     | 0      |

| KW11LE | STOP mode release level of KWI11 pin        | 0: Low level<br>1: High level |
|--------|---------------------------------------------|-------------------------------|
| KW11EN | Input enable / disable control of KWI11 pin | 0: Disable<br>1: Enable       |
| KW10LE | STOP mode release level of KWI 10 pin       | 0: Low level<br>1: High level |
| KW10EN | Input enable / disable control of KWI10 pin | 0: Disable<br>1: Enable       |
| KW9LE  | STOP mode release level of KWI9 pin         | 0: Low level<br>1: High level |
| KW9EN  | Input enable / disable control of KWI9 pin  | 0: Disable<br>1: Enable       |
| KW8LE  | STOP mode release level of KWI8 pin         | 0: Low level<br>1: High level |
| KW8EN  | Input enable / disable control of KWI8 pin  | 0: Disable<br>1: Enable       |

#### Key-on Wakeup Control Register 3

| KWUCR1<br>(0x0FCB) | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Bit Symbol         | KW15LE | KW15EN | KW14LE | KW14EN | KW13LE | KW13EN | KW12LE | KW12EN |
| Read/Write         | R/W    |
| After reset        | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

| KW15LE | STOP mode release level of KWI 15 pin       | 0: Low level<br>1: High level |
|--------|---------------------------------------------|-------------------------------|
| KW15EN | Input enable / disable control of KWI15 pin | 0: Disable<br>1: Enable       |
| KW14LE | STOP mode release level of KWI 14 pin       | 0: Low level<br>1: High level |
| KW14EN | Input enable / disable control of KWI14 pin | 0: Disable<br>1: Enable       |
| KW13LE | STOP mode release level of KWI 13 pin       | 0: Low level<br>1: High level |
| KW13EN | Input enable / disable control of KWI13 pin | 0: Disable<br>1: Enable       |

Name : MQ6812/MQ6821/MQ6822 Datasheet

| KW12LE | STOP mode release level of KWI12 pin        | 0: Low level<br>1: High level |
|--------|---------------------------------------------|-------------------------------|
| KW12EN | Input enable / disable control of KWI12 pin | 0: Disable<br>1: Enable       |

# 4.9.3 Function

By using the key-on wakeup function, the STOP mode can be released at KWIm pin (m: 0 through 15). To designate the KWIm pin as a STOP mode release pin, it is necessary to configure the key-on wakeup control register (KWUCRn) (n: 0 or 1).

### 4.9.3.1 Setting KWUCRn and P4PU Registers

To designate a key-on wakeup pin (KWIm) as a STOP mode release pin, set KWUCRn <KWmEN> to "1". After KWIm pin is set to "1" at KWUCRn <KWmEN>, a specific STOP mode release level can be specified for this pin at KWUCRn <KWmLE>. If KWUCRn <KWmLE> is set to "0", STOP mode is released when an input is at a low level. If it is set to "1", STOP mode is released when an input is at a low level. If it is set to "1", STOP mode by inputting a high-level signal into a KWIO pin, set KWUCRO <KWOEN> to "1", and KWUCRO <KWOLE> to "1".

#### 4.9.3.2 Starting STOP Mode

To start the STOP mode, set SYSCR1 <RELM> to "1" (level release mode), and SYSCR1 <STOP> to "1".

To use the key-on wakeup function, do not set SYSCR1 <RELM> to "0" (edge release mode). If the key-on wakeup function is used in edge release mode, STOP mode cannot be released. This is because the KWIm pin enabling inputs to be received is at a release level after the STOP mode starts.

#### 4.9.3.3 Releasing STOP Mode

To release STOP mode, input a specific release level into the KWIm pin for which receipt of inputs is enabled.

If the KWIm pin is already at a release level when the STOP mode starts, the following instruction will be executed without starting the STOP mode (with no warm-up performed).

Note): Do not applied an analog voltage to KWIm pin for which receipt of inputs is enabled by the key-on wakeup control register (KWUCRn) setting, or a penetration current will flow.

# Page: 55/ 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 5. Reset Function

# 5.1 Reset Control Circuit

The reset circuit controls the external and internal factor resets and initializes the system.

# 5.1.1 Configuration

The reset circuit controls the external and internal factor resets and initializes the system.

- 1. External reset input (RESETB, external factor)
- 2. Power-on reset (POR, internal factor)
- 3. Voltage detection reset1 (LVD1, internal factor)
- 4. Voltage detection reset2 (LVD2, internal factor)
- 5. Watchdog timer reset (WDT, internal factor)
- 6. Watchdog timer reset2 (WDT2, internal factor)
- 7. System clock reset (internal factor)
- 8. Flash standby reset (internal factor)



Figure 5.1 Reset Control Circuit

Page: 56 / 278

# 5.1.2 Control

The reset control circuit is controlled by system control register 3 (SYSCR3), system control register 4 (SYSCR4), system control status register (SYSSR4) and the internal factor reset detection status register (IRSTSR).

#### System Control Register 3

| SYSCR3<br>(0x0FDE) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------------------|---|---|---|---|---|---|---|--------|
| Bit Symbol         | - | - | - | - | - | - | - | RSTDIS |
| Read/Write         | R | R | R | R | R | R | R | R/W    |
| After reset        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

| RSTDIS | External reset input enable register | 0: Enable the external reset input<br>1: Disable the external reset input |
|--------|--------------------------------------|---------------------------------------------------------------------------|
|--------|--------------------------------------|---------------------------------------------------------------------------|

Note 1): The enabled SYSCR3 <RSTDIS> is initialized by a power-on reset only, and cannot be initialized by an external reset input or internal factor reset. The value written in SYSCR3 is reset by a power-on reset, external reset input or internal factor reset.

Note 2): The value of SYSCR3 <RSTDIS> is invalid until 0xB2 is written into SYSCR4.

Note 3): After SYSCR3 <RSTDIS> is modified, SYSCR4 should be written 0xB2 (Enable code for SYSCR3 <RSTDIS>) in NORMAL1 mode when fcgck is fc/4 (CGCR <FCGCKSEL> = 00). Otherwise, SYSCR 3<RSTDIS> may be enabled at unexpected timing. Note 4): Bits 7 to 3 of SYSCR3 are read as "0".Bit2 to Bit 1 of SYSCR3 are system reseved, do not change the default value.

## System Control Register 4

| SYSCR4<br>(0x0FDF) | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|--------------------|------------|---|---|---|---|---|---|---|--|--|
| Bit Symbol         | SYSCR4     |   |   |   |   |   |   |   |  |  |
| Read/Write         | Write only |   |   |   |   |   |   |   |  |  |
| After reset        | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

|        |                                    | 0xB2:            | Enable the contents of SYSCR3 <rstdis></rstdis>         |
|--------|------------------------------------|------------------|---------------------------------------------------------|
| SYSCR4 | Write the SYSCR3 data control code | 0x71:<br>Others: | Enable the contents of IRSTSR <fclr><br/>Invalid</fclr> |

Note 1): SYSCR4 is a write-only register, and must not be accessed by using a read-modify-write instruction, such as a bit operation.

Note 2): After SYSCR3 <RSTDIS> is modified, SYSCR4 should be written 0xB2 (Enable code for SYSCR3 <RSTDIS>) in NORMAL mode when fcgck is fc/4 (CGCR<FCGCKSEL>=00). Otherwise, SYSCR3 <RSTDIS> may be enabled at unexpected timing. Note 3): After IRSTSR <FCLR> is modified, SYSCR4 should be written 0x71 (Enable code for IRSTSR <FCLR> in NORMAL mode when fcgck is fc/4 (CGCR <FCGCKSEL>=00). Otherwise, IRSTSR <FCLR> may be enabled at unexpected timing.

# Page: 57 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

#### System Control Status Register 4

| SYSSR4<br>(0x0FDF) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|--------------------|---|---|---|---|---|---|---|---------|
| Bit Symbol         | - | - | - | - | - | - | - | RSTDISS |
| Read/Write         | R | R | R | R | R | R | R | R       |
| After reset        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0       |

| RSTDISS | Status of external reset input enable register | 0: The enabled SYSCR3 <rstdis> data is "0".<br/>1: The disabled SYSCR3&lt; RSTDIS &gt; data is "1".</rstdis> |
|---------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
|---------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------|

Note 1): The enabled SYSCR3 <RSTDIS> is initialized by a power-on reset only, and cannot be initialized by any other reset signals. The value written in SYSCR3 is reset by a power-on reset and other reset signals.

Note 2): Bits 7 to 3 of SYSCR4 are read as "0". Bit2 to Bit 1 of SYSCR3 are system reseved.

#### Internal Factor Reset Detection Status Register

| IRSTSR<br>(0x0FCC) | 7              | 6     | 5 | 4 | 3      | 2      | 1     | 0     |
|--------------------|----------------|-------|---|---|--------|--------|-------|-------|
| Bit Symbol         | FCLR<br>WDT2RF | FLSRF | - | - | LVD2RF | LVD1RF | SYSRF | WDTRF |
| Read/Write         | W              | R     | - | - | R      | R      | R     | R     |
| After reset        | 0              | 0     | 0 | 0 | 0      | 0      | 0     | 0     |

| FCLR   | Flag initialization control              | 0: -<br>1: Clear the internal factor reset flag to "0". |
|--------|------------------------------------------|---------------------------------------------------------|
| FLSRF  | Flash standby reset detection flag       | 0:-<br>1: Detect the flash standby reset.               |
| TRMDS  | Trimming data status                     | 0: -<br>1: Detect state of abnormal trimming data       |
| TRMRF  | Trimming data reset detection flag       | 0: -<br>1: Detects the trimming data reset.             |
| LVD2RF | Voltage detection reset 2 detection flag | 0: -<br>1: Detect the voltage detection 2 reset.        |
| LVD1RF | Voltage detection reset 1 detection flag | 0: -<br>1: Detect the voltage detection 1 reset.        |
| SYSRF  | System clock reset detection flag        | 0: -<br>1: Detect the system clock reset.               |
| WDTRF  | Watchdog timer reset detection flag      | 0:-<br>1: Detect the watchdog timer reset.              |

Note 1/: IRSTSR is initialized by a power-on reset.

Note 2): Care must be taken in system designing since the IRSTSR may not fulfill its functions due to disturbing noise and other effects.

Note 3): IRSTSR <FCLR> is initialized by a power-on reset, or an internal reset factor.

Note 4): Set IRSTSR <FCLR> to "1" and write 0x71 to SYSCR4. This enables IRSTSR <FCLR> and the internal factor reset detection status register is clear to "0". IRSTSR <FCLR> is cleared to "0" automatically after initializing the internal factor reset detection status register.

Note 5]: After IRSTSR <FCLR> is modified, SYSCR4 should be written 0x71 [Enable code for IRSTSR <FCLR> in NORMAL mode when fcgck is fc/4 [CGCR <FCGCKSEL> = 00]. Otherwise, IRSTSR <FCLR> may be enabled at unexpected timing.

### Page: 58 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

Note 6):Bit 7 of IRSTSR write as FCLR/Flag initialization control) function; Bit 7 of IRSTSR read as WDR2RF/Watch Dog 2 reset flag).

Note 7):Bit 7 of IRSTSR is read as 0.

# 5.1.3 Function

The power-on reset, external reset input and internal factor reset signals are input to the warm-up circuit of the clock generator.

During reset, the warm-up counter circuit is reset, and the CPU and the peripheral circuits are reset.

After reset is released, the warm-up counter starts counting the high frequency clock (fc), and executes the warm-up operation that follows reset release.

During the warm-up operation that follows reset release, the trimming data is loaded from the embedded flash memory for adjustment of the ladder resistor that generates the comparison voltage for the power-on reset and the voltage detection circuits.

When the warm-up operation that follows reset release is finished, the CPU starts execution of the program from the reset vector address stored in addresses 0xFFFE to 0xFFFF.

When a reset signal is input during the warm-up operation that follows reset release, the warm-up counter circuit is reset.

| Built-in Hardware                                                | During Reset  | During the warm-up<br>operation that follows<br>reset release | Immediately after the<br>warm-up operation that<br>follows reset release |
|------------------------------------------------------------------|---------------|---------------------------------------------------------------|--------------------------------------------------------------------------|
| Program counter (PC)                                             | 0xFFFE        | 0xFFFE                                                        | 0xFFFE                                                                   |
| Stack pointer (SP)                                               | 0x00FF        | 0x00FF                                                        | 0x00FF                                                                   |
| RAM                                                              | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| General-purpose registers<br>(W, A, B, C, D, E, H, L, IX and IY) | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| Jump status flag (JF)                                            | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| Zero flag (ZF)                                                   | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| Carry flag (CF)                                                  | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| Half carry flag (HF)                                             | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| Sign flag (SF)                                                   | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| Overflow flag (VF)                                               | Indeterminate | Indeterminate                                                 | Indeterminate                                                            |
| Interrupt master enable flag (IMF)                               | 0             | 0                                                             | 0                                                                        |
| Individual interrupt enable flag (EF)                            | 0             | 0                                                             | 0                                                                        |

# Page: 59/ 278

# 汉芝电子股份有限公司

iMQ Technology Inc.

#### No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Interrupt latch (IL)                   | 0                     | 0                     | 0                     |
|----------------------------------------|-----------------------|-----------------------|-----------------------|
| Hi-freq. clock oscillation circuit     | Oscillation enabled   | Oscillation enabled   | Oscillation enabled   |
| Low-freq. clock oscillation circuit    | Oscillation disabled  | Oscillation disabled  | Oscillation disabled  |
| Warm-up counter                        | Reset                 | Start                 | Stop                  |
| Timing generator prescaler and divider | 0                     | 0                     | 0                     |
| Watchdog timer                         | Disabled              | Disabled              | Enabled               |
| Voltage detection circuit              | Disabled or enabled   | Disabled or enabled   | Disabled or enabled   |
| I/O port pin status                    | HiZ                   | HiZ                   | HiZ                   |
| Special function register              | Refer to the SFR map. | Refer to the SFR map. | Refer to the SFR map. |

#### Table 5.1 Initialization of Built-in Hardware by Reset Operation and Its Status after Release

Note 1): The voltage detection circuits are disabled by an external reset input or power-on reset only. Note 2): "HiZ" indicates high-impedance.

The reset operation is common to the power-on reset, external reset input and internal factor resets, except for the initialization of some special function registers and the initialization of the voltage detection circuits.

When a reset is applied, the peripheral circuits become the states as shown in Table 5.1.

# 5.1.4 Reset Signal Generating Factors

Reset signals are generated by each factor as follows:

# 5.1.4.1 External Reset Input (RESETB Pin Input)

Port P10 is also used as the RESETB pin, and it serves as the RESETB pin after the power is turned on.

iMQ reserves the right to change the information in this document without prior notice. Please contact iMQ to obtain the latest version of product specification before placing your order. Use of iMQ devices in life support is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless iMQ from any and all damages, claims, suits or expenses resulting from such use.

# Page: 60 / 278



#### Figure 5.2 External Reset Input (During Power-Up)

If the supply voltage is within the recommended operating voltage range, the RESETB pin is kept at the "L" level for 5 µs with the stabilized oscillation, and then a reset is applied.



## Figure 5.3 External Reset Input (when the power is stabilized)

In each case, after a reset is applied, it is released by turning the RESETB pin to "H" and the warmup operation that follows reset release gets started.

Note): When the supply voltage is equal to or lower than the detection voltage of the power-on reset circuit, the poweron reset remains active, even if the RESETB pin is turned to "H".

# Page: 61/ 278

## 5.1.4.2 Power-on Reset

The power-on reset is an internal factor reset that occurs when the power is turned on.

When power supply voltage goes on, if the supply voltage is equal to or lower than the releasing voltage of the power-on reset circuit, a reset signal is generated, and if it is higher than the releasing voltage of the power-on reset circuit, a reset signal is released.

When power supply voltage goes down, if the supply voltage is equal to or lower than the detecting voltage of the power-on reset circuit, a reset signal is generated. Refer to "5.2 Power-on Reset circuit".

### 5.1.4.3 Voltage Detection Reset

The voltage detection reset is an internal factor reset that occurs when it is detected that the supply voltage has reached a predetermined detection voltage. Refer to "5.3 Voltage Detection Circuit".

## 5.1.4.4 Watchdog Timer Reset

The watchdog timer reset is an internal factor reset that occurs when an overflow of the watchdog timer is detected. Refer to "10.1 Watchdog Timer/ Watchdog Timer 2"

### 5.1.4.5 Watchdog Timer2 Reset

The watchdog timer reset is an internal factor reset that occurs when an overflow of the watchdog timer is detected. Refer to "10.1 Watchdog Timer/ Watchdog Timer 2"

### 5.1.4.6 System Clock Reset

The system clock reset is an internal factor reset that occurs when it is detected that the oscillation enable register is set to a combination that puts the CPU into deadlock. Refer to "6 System Clock Control".

### 5.1.4.7 Flash Standby Reset

The flash standby reset is an internal factor reset generated by the reading or writing of data of the flash memory while it is on standby. Refer to "14 Flash Memory".

### 5.1.4.8 Internal Factor Reset Detection Status Register

By reading the internal factor reset detection status register IRSTSR after the release of an internal

# Page: 62/ 278

factor reset, except the power-on reset, the factor which causes a reset can be detected.

The internal factor reset detection status register is initialized by an external reset input or poweron reset.

Set IRSTSR <FCLR> to "1" and write 0x71 to SYSCR4. This enables IRSTSR <FCLR> and the internal factor reset detection status register is clear to "0". IRSTSR <FCLR> is cleared to "0" automatically after initializing the internal factor reset detection status register.

Note 1): Care must be taken in system designing since the IRSTSR may not fulfill its functions due to noises and other disturbances.

Note 2]: After IRSTSR <FCLR> is modified, SYSCR4 should be written 0x71 (Enable code for IRSTSR <FCLR> in NORMAL mode when fcgck is fc/4 (CGCR <FCGCKSEL> = 00). Otherwise, IRSTSR <FCLR> may be enabled at unexpected timing.

### 5.1.4.9 How to Use P10 as an External Reset

To use P10 as an external reset, keep P10 at the "H" level until the power is turned on and the warm-up operation that follows reset release is finished.

After the warm-up operation that follows power-on reset is finished, set P1CR0 to "0", and connect a pull-up resistor to P10. Then clear SYSCR3 <RSTDIS> to "0" and write 0xB2 to SYSCR4. This enables the external reset function and makes P10 as a reset input pin.

To use the pin as an IO pin when it is used as a reset, set SYSCR3 <RSTDIS> to "1" and write 0xB2 to SYSCR4. This enables the IO function and makes the pin usable as an open-drain IO pin.

Note 1): If you switch the external reset input pin to a port or switch the pin used as a port to the external reset input pin, do it when the pin is stabilized at the "H" level. Switching the pin function when the "L" level is input may cause a reset. Note 2): If the external reset input is used as a port, the statement which clears SYSCR3 <RSTDIS> to "0" is not written in a program. By this abnormal execution of program, the external reset input set as a port may be changed as the external reset input at unexpected timing.

Note 3]: After SYSCR3 <RSTDIS> is modified, SYSCR4 should be written 0xB2 (Enable code for SYSCR3 <RSTDIS>) in NORMAL1 mode when fcgck is fc/4 (CGCR <FCGCKSEL> = 00). Otherwise, SYSCR3 <RSTDIS> may be enabled at unexpected timing.

### Page: 63/ 278

# 5.2 Power-on Reset Circuit

The power-on reset circuit generates a reset when the power is turned on. When the supply voltage is lower than the detection voltage of the power-on reset circuit, a power-on reset signal is generated.

# 5.2.1 Configuration

The power-on reset circuit consists of a reference voltage generation circuit and a comparator. The supply voltage divided by ladder resistor is compared with the voltage generated by the reference voltage generation circuit by the comparator.



Figure 5.4 Power-on Reset Circuit

# 5.2.2 Function

When power supply voltage goes on, if the supply voltage is equal to or lower than the releasing voltage of the power-on reset circuit, a power-on reset signal is generated and if it is higher than the releasing voltage of the power-on reset circuit, a power-on reset signal is released.

When power supply voltage goes down, if the supply voltage is equal to or lower than the detecting voltage of the power-on reset circuit, a power-on reset signal is generated.

Until the power-on reset signal is generated, a warm-up circuit and a CPU is reset.

When the power-on reset signal is released, the warm-up circuit is activated. The reset of the CPU and peripheral circuits is released after the warm-up time that follows reset release has elapsed.

Increase the supply voltage into the operating range during the period from detection of the poweron reset release voltage until the end of the warm-up time that follows reset release. If the supply voltage has not reached the operating range by the end of the warm-up time that follows reset release, the MCU cannot operate properly.

# Page: 64/ 278



Note 1): The power-on reset circuit may operate improperly, depending on fluctuations in the supply voltage (VDD). Refer to the electrical characteristics and take them into consideration when designing equipment.

# 5.3 Voltage Detection Circuit

The voltage detection circuit detects any decrease in the supply voltage and generates INTLVDinterrupt request signals and voltage detection reset signals.

Note): The voltage detection circuit may operate improperly, depending on fluctuations in the supply voltage (VDD). Refer to the electrical characteristics and take them into consideration when designing equipment.

# 5.3.1 Configuration

The voltage detection circuit consists of a reference voltage generation circuit, a detection voltage level selection circuit, a comparator and control registers.

The supply voltage (VDD) is divided by the ladder resistor and input to the detection voltage selection circuit. A voltage is selected in the detection voltage selection circuit, depending on the detection voltage (VDxLVL), and compared to the reference voltage in the comparator. When the supply voltage (VDD) becomes lower than the detection voltage (VDxLVL), a voltage detection interrupt request signal or a voltage detection reset signal is generated. (x = 1 to 2)

Whether to generate a voltage detection reset signal or an INTLVD interrupt request signal can be programmed by software. In the former case, a voltage detection reset signal is generated when the supply voltage (VDD) becomes lower than the detection voltage (VDxLVL). In the latter case, an INTLVD interrupt request signal is generated when the supply voltage (VDD) falls to the detection

# Page: 65/ 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

voltage level.

Note): Since the comparators used for voltage detection do not have a hysteresis structure, INTLVD interrupt request signals may be generated frequently if the supply voltage (VDD) is close to the detection voltage (VDxLVL). INTLVD interrupt request signals may be generated not only when the supply voltage falls to the detection voltage but also when it rises to the detection voltage.



Figure 5.6 Voltage Detection Circuit

iMQ reserves the right to change the information in this document without prior notice. Please contact iMQ to obtain the latest version of product specification before placing your order. Use of iMQ devices in life support is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless iMQ from any and all damages, claims, suits or expenses resulting from such use.

## Page: 66 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 5.3.2 Control

The voltage detection circuit is controlled by voltage detection control registers 1 and 2.

#### Voltage Detection Control Register 1

| VDCR1<br>(0x0FC6) | 7    | 6     | 5      | 4 | 3    | 2     | 1      | 0 |
|-------------------|------|-------|--------|---|------|-------|--------|---|
| Bit Symbol        | VD2F | VD2SF | VD2LVL |   | VD1F | VD1SF | VD1LVL |   |
| Read/Write        | R/W  | R     | R/W    |   | R/W  | R     | R/     | W |
| After reset       | 0    | 0     | 1      | 0 | 0    | 0     | 0      | 0 |

|        | Voltage detection 2 flag (Retain the state when VDD <vd2lvl detected)<="" is="" th=""><th>Read</th><th>Writer</th></vd2lvl>                                                                     |                      | Read                                                                         | Writer                  |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------------------------------------------------|-------------------------|
| VD2F   |                                                                                                                                                                                                 |                      | 0: VDD ≥ VD2LVL<br>1: VDD < VD2LVL                                           | Clears VD2F to "0"<br>- |
| VD2SF  | Voltage detection 2 status flag (Magnitude relation of VDD and VD2LVL when they are read)                                                                                                       | 0<br>1               | 0: VDD ≥ VD2LVL<br>1: VDD < VD2LVL                                           |                         |
| VD2LVL | Selection for detection voltage 2                                                                                                                                                               | 00<br>01<br>10<br>11 | 2.85V +/- 0.15 V<br>2.65V +/- 0.15 V<br>2.35V +/- 0.10 V<br>2.00V +/- 0.10 V |                         |
|        | Voltage detection 1 flag (Detain the state                                                                                                                                                      |                      | Read                                                                         | Writer                  |
| VD1F   | Voltage detection 1 flag (Retain the state when VDD <vd1lvl detected)<="" is="" td=""><td>0<br/>1</td><td>0: VDD ≥ VD1LVL<br/>1: VDD &lt; VD1LVL</td><td>Clears VD1F to "0"<br/>-</td></vd1lvl> | 0<br>1               | 0: VDD ≥ VD1LVL<br>1: VDD < VD1LVL                                           | Clears VD1F to "0"<br>- |
| VD1SF  | Voltage detection 1 status flag (Magnitude relation of VDD and VD1LVL when they are read)                                                                                                       |                      | 0: VDD ≥ VD1LVL<br>1: VDD < VD1LVL                                           |                         |
| VD1LVL | Selection for detection voltage 1                                                                                                                                                               | 00<br>01<br>10<br>11 | 4.50V +/- 0.20 V<br>4.20V +/- 0.20 V<br>3.70V +/- 0.20 V<br>3.15V +/- 0.20 V |                         |

Note 1]: VDCR1 is initialized by a power-on reset or an external reset input.

Note 2]: When VD2F or VD1F is cleared by the software and is set due to voltage detection at the same time, the setting due

to voltage detection is given priority.

Note 3]: VD2F and VD1F cannot be programmed to "1" by the software.

#### Voltage Detection Control Register 2

| VDCR2<br>(0x0FC7) | 7 | 6 | 5 | 4 | 3      | 2     | 1      | 0     |
|-------------------|---|---|---|---|--------|-------|--------|-------|
| Bit Symbol        | - | - | - | - | VD2MOD | VD2EN | VD1MOD | VD1EN |
| Read/Write        | R | R | R | R | R/W    | R/W   | R/W    | R/W   |
| After reset       | 0 | 0 | 0 | 0 | 0      | 0     | 0      | 0     |

| VD2MOD | Select the operation mode of voltage detection 2      | 0: Generate a INTLVDinterrupt request signal<br>1: Generate a voltage detection reset 2 signal    |
|--------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| VD2EN  | Enable / disable the operation of voltage detection 2 | 0: Disable the operation of voltage detection 2<br>1: Enable the operation of voltage detection 2 |
| VD1MOD | Select the operation mode of voltage detection 1      | 0: Generate a INTLVD interrupt request signal<br>1: Generate a voltage detection reset 1 signal   |

# 汉芝电子股份有限公司 iMO Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

| VD1EN |  | 0: Disable the operation of voltage detection 1<br>1: Enable the operation of voltage detection 1 |
|-------|--|---------------------------------------------------------------------------------------------------|
|-------|--|---------------------------------------------------------------------------------------------------|

Note 1): VDCR2 is initialized by a power-on reset or an external reset input. Note 2): Bits 7 and 6 of VDCR2 are read as "0".

# 5.3.3 Function

Two detection voltages (VDxLVL, x = 1 to 2) can be set in the voltage detection circuit. For each voltage, enabling/disabling the voltage detection and the operation to be executed when the supply voltage (VDD) falls to or below the detection voltage (VDxLVL) can be programmed.

# 5.3.3.1 Enabling / Disabling the Voltage Detection Operation

Setting VDCR2 <VDxEN> to "1" enables the voltage detection operation. Setting it to "0" disables the operation. VDCR2 <VDxEN> is cleared to "0" immediately after a power-on reset or a reset by an external reset input is released.

Note): When the supply voltage (VDD) is lower than the detection voltage (VDxLVL), setting VDCR2 <VDxEN> to "1" generates an INTLVD interrupt request signal or a voltage detection reset signal at the time.

# 5.3.3.2 Selecting the Voltage Detection Operation Mode

When VDCR2 <VDxMOD> is set to "0", the voltage detection operation mode is set to generate INTLVD interrupt request signals. When VDCR2 <VDxMOD> is set to "1", the operation mode is set to generate voltage detection reset signals.

## (a) When the operation mode is set to generate INTLVD interrupt signals (VDCR2 <VDxMOD>="0")

When VDCR2<VDxEN>="1", an INTLVD interrupt request signal is generated when the supply voltage (VDD) falls to the detection voltage (VDxLVL).





Page: 68 / 278

# (b) When the operation mode is set to generate voltage detection reset signals (VDCR2 <VDxMOD>="1")

When VDCR2 <VDxEN> = "1", a voltage detection reset signal is generated when the supply voltage (VDD) becomes lower than the detection voltage (VDxLVL).

VDCR1 and VDCR2 are initialized by a power-on reset or an external reset input only. A voltage detection reset signal is generated continuously as long as the supply voltage (VDD) is lower than the detection voltage (VDxLVL).



Figure 5.8 Voltage Detection Reset Signal

### 5.3.3.3 Selecting the Detection Voltage Level

Select a detection voltage at VDCR1<VDxLVL>.

### 5.3.3.4 Voltage Detection Flag and Voltage Detection Status Flag

The magnitude relation between the supply voltage (VDD) and the detection voltage (VDxLVL) can be checked by reading VDCR1 <VDxF> and VDCR1 <VDxSF>.

If VDCR2 <VDxEN> is set at "1", when the supply voltage (VDD) becomes lower than the detection voltage (VDxLVL), VDCR1 <VDxF> is set to "1" and is held in this state. VDCR1<VDxF> is not cleared to "0" when the supply voltage (VDD) becomes equal to or higher than the detection voltage (VDxLVL).

When VDCR2 <VDxEN> is cleared to "0" after VDCR1 <VDxF> is set to "1", the previous state is still held. To clear VDCR1 <VDxF>, "0" must be written to it.

If VDCR2 <VDxEN> is set at "1", when the supply voltage (VDD) becomes lower than the detection voltage (VDxLVL), VDCR1 <VDxSF> is set to "1". When the supply voltage (VDD) becomes equal to or higher than the detection voltage (VDxLVL), VDCR1 <VDxSF> is cleared to "0".

# Page: 69/ 278

#### Unlike VDCR1 <VDxF>, VDCR1 <VDxSF> does not hold the set state.

Note 1): When the supply voltage (VDD) becomes lower than the detection voltage (VDxLVL) in the STOP, IDLE0 or SLEEPO mode, the voltage detection flag and the voltage detection status flag are changed after the operation mode is returned to NORMAL or SLOW mode.

Note 2]: Depending on the voltage detection timing, the voltage detection status flag (VDxSF) may be changed earlier than the voltage detection flag (VD2F) by a maximum of 2/fcgck[s].



Figure 5.9 Changes in the Voltage Detection Flag and the Voltage Detection Status Flag

# 5.3.4 Register Setting

### 5.3.4.1 When the Operation Mode is Set to Generate INTLVD Interrupt Request Signals

When the operation mode is set to generate INTLVD interrupt request signal, make the following setting:

1. Clear the voltage detection circuit interrupt enable flag to "0".

2. Set the detection voltage at VDCR1<VDxLVL>, x = 1 to 2.

3. Clear VDCR2 <VDxMOD> to "0" to set the operation mode to generate INTLVD interrupt request signals.

4. Set VDCR2<VDxEN> to "1" to enable the voltage detection operation.

5. Wait for 5  $\mu$ s or more until the voltage detection circuit becomes stable.

6. Make sure that VDCR1 <VDxSF> is "0".

7. Clear the voltage detection circuit interrupt latch to "0" and set the interrupt enable flag to "1" to enable interrupts.

Note): When the supply voltage (VDD) is close to the detection voltage (VDxLVL), voltage detection request signals may be generated frequently. If this may pose any problem, execute appropriate wait processing depending on fluctuations in the system power supply and clear the interrupt latch before returning from the INTLVD interrupt service routine.

# Page: 70 / 278

To disable the voltage detection circuit while it is enabled with the INTLVD interrupt request, make the following setting:

1. Clear the voltage detection circuit interrupt enable flag to "0".

2. Clear VDCR2 <VDxEN> to "0" to disable the voltage detection operation.

Note): If the voltage detection circuit is disabled without clearing interrupt enable flag, unexpected interrupt request may occur.

### 5.3.4.2 When the Operation Mode is Set to Generate Voltage Detection Reset Signals

When the operation mode is set to generate voltage detection reset signals, make the following setting:

1. Clear the voltage detection circuit interrupt enable flag to "0".

2. Set the detection voltage at VDCR1 <VDxLVL>, x = 1 to 2.

3. Clear VDCR2 <VDxMOD> to "0" to set the operation mode to generate INTLVD interrupt request signals.

4. Set VDCR2 <VDxEN> to "1" to enable the voltage detection operation.

5. Wait for 5 µs or more until the voltage detection circuit becomes stable.

6. Make sure that VDCR1 <VDxSF> is "0".

7. Clear VDCR1 <VDxF> to "0".

8. Set VDCR2 <VDxMOD> to "1" to set the operation mode to generate voltage detection reset signals.

Note 1): VDCR1 and VDCR2 are initialized by a power-on reset or an external reset input only. If the supply voltage (VDD) becomes lower than the detection voltage (VDxLVL) in the period from release of the voltage detection reset until clearing of VDCR2 <VDxEN> to "0", a voltage detection reset signal is generated immediately.

Note 2): The voltage detection reset signals are generated continuously as long as the supply voltage (VDD) is lower than the detection voltage (VDxLVL).

To disable the voltage detection circuit while it is enabled with the voltage detection reset, make the following setting:

1. Clear the voltage detection circuit interrupt enable flag to "0".

2. Clear VDCR2 <VDxMOD> to "0" to set the operation mode to generate INTLVD interrupt request signals.

3. Clear VDCR2 <VDxEN> to "0" to disable the voltage detection operation.

Note): If the voltage detection circuit is disabled without clearing interrupt enable flag, unexpected interrupt request may occur.

# Page: 71/ 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 6. System Clock Controller

# 6.1 Configuration

The system clock controller consists of a clock generator, a clock gear, a timing generator, a warm-up counter and an operation mode control circuit.



Note 1): The location of external crystal is recommended to be as close to MCU as possible.

Figure 6.1 System Clock Controller

iMQ reserves the right to change the information in this document without prior notice. Please contact iMQ to obtain the latest version of product specification before placing your order. Use of iMQ devices in life support is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless iMQ from any and all damages, claims, suits or expenses resulting from such use.

# Page: 72 / 278

# 6.2 Control

The system clock controller is controlled by system control register 1 (SYSCR1), system control register 2 (SYSCR2), the warm-up counter control register (WUCCR), the warm-up counter data register (WUCDR) and the clock gear control register (CGCR).

### System Control Register 1

| SYSCR1<br>(0x0FDC) | 7    | 6    | 5     | 4     | 3      | 2 | 1 | 0  |
|--------------------|------|------|-------|-------|--------|---|---|----|
| Bit Symbol         | STOP | RELM | OUTEN | DV9CK | OSCSEL | - | - | -  |
| Read/Write         | R/W  | R/W  | R/W   | R/W   | R/W    | R | R | R  |
| After reset        | 0    | 0    | 0     | 0     | 0      | 0 | 0 | 0- |

| STOP   | Activate the STOP mode                           | 0<br>1 | Operate the CPU and the peripheral circuit<br>Stop the CPU and the peripheral circuit (activate the STOP mode)                                                                                                 |
|--------|--------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RELM   | Select the STOP mode release method              | 0<br>1 | Edge-sensitive release mode (Release the STOP mode at the rising edge of the STOP mode release signal)<br>Level-sensitive release mode (Release the STOP mode at the "H"level of the STOP mode release signal) |
| OUTEN  | Select the port output state in the STOP mode    | 0<br>1 | High impedance<br>Output hold                                                                                                                                                                                  |
| DV9CK  | Select the input clock to stage 9 of the divider | 0<br>1 | fcgck/2 <sup>9</sup><br>fs/4                                                                                                                                                                                   |
| OSCSEL | Select the high-frequency reference clock (fh)   | 0<br>1 | Internal high-frequency clock (fosc)<br>External high-frequency clock (fc)                                                                                                                                     |

Note 1):fosc: Internal high-frequency clock [Hz], fc: External high-frequency clock [Hz], fcgck: Gear clock [Hz], fs: External lowfrequency clock [Hz]

Note 2]: Bits 2, 1 and 0 of SYSCR1 are read as "0".

Note 3): If the STOP mode is activated with SYSCR1 <OUTEN> set at "0", the port internal input is fixed to "0". Therefore, an external interrupt may be set at the falling edge, depending on the pin state when the STOP mode is activated.

Note 4]: Writing of the second byte data will be executed improperly if the operation is switched to the STOP state by an instruction, such as LDW, which executes 2-byte data transfer at a time.

Note 5): Don't set SYSCK1 < DV9CK> to "1" before the oscillation of the external low-frequency clock oscillation circuit becomes stable.

Note 6): In the SLOW1/2 or SLEEP1 mode, fs/4 is input to stage 9 of the divider, regardless of the state of SYSCR1 < DV9CK >. Note 7): SYSCR1 <OSCSEL> should be set while SYSCR2 <SYSCK> is "0" (during the NORMAL1 or NORMAL2 mode). Writing to SYSCR1 <OSCSEL> while SYSCR2 <SYSCK> = "1" (during the SLOW1 or SLOW2 mode) has no effect.

# Page: 73/ 278

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| System | Contr | ol Reg | iste | er 2 |
|--------|-------|--------|------|------|
|        |       |        |      |      |

| SYSCR2<br>(0x0FDD) | 7     | 6   | 5    | 4     | 3    | 2      | 1 | 0 |
|--------------------|-------|-----|------|-------|------|--------|---|---|
| Bit Symbol         | OSCEN | XEN | XTEN | SYSCK | IDLE | TGHALT | - | - |
| Read/Write         | R/W   | R/W | R/W  | R/W   | R/W  | R/W    | R | R |
| After reset        | 1     | 0   | 0    | 0     | 0    | 0      | 0 | 0 |

| OSCEN  | Control internal high-freq.          | 0      | Disable internal high-frequency clock oscillation circuit                                                                                                                              |
|--------|--------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | clock (fosc)                         | 1      | Enable internal high-frequency clock oscillation circuit                                                                                                                               |
| XEN    | Control the external high-           | 0      | Stop oscillation                                                                                                                                                                       |
|        | freq. clock (fc)                     | 1      | Continue or start oscillation                                                                                                                                                          |
| XTEN   | Control the external low-            | 0      | Stop oscillation                                                                                                                                                                       |
|        | freq. clock (fs)                     | 1      | Continue or start oscillation                                                                                                                                                          |
| SYSCK  | Select a system clock                | 0<br>1 | Gear clock (fcgck) (NORMAL1/2 or IDLE1/2 mode)<br>Low-frequency clock (fs/4) (SLOW1/2 or SLEEP1 mode)                                                                                  |
| IDLE   | CPU and WDT control                  | 0      | Operate the CPU and the WDT                                                                                                                                                            |
|        | (IDLE1/2 or SLEEP1 mode)             | 1      | Stop the CPU and the WDT (Activate IDLE 1/2 or SLEEP1 mode)                                                                                                                            |
| TGHALT | TG control<br>(IDLE0 or SLEEP0 mode) | 0<br>1 | Enable the clock supply from the TG to all the peripheral circuits<br>Disable the clock supply from the TG to the peripheral circuits<br>except the TBT(Activate IDLE0 or SLEEP0 mode) |

Note 1): fosc: Internal high-frequency clock [Hz], fc: External high-frequency clock [Hz], fcgck: Gear clock [Hz], fs: External low-frequency clock [Hz]

Note 2]: WDT: Watchdog timer, TG: Timing generator

Note 3/: Don't set both SYSCR2 <IDLE> and SYSCR2 <TGHALT> to "1" simultaneously.

Note 4]: Writing of the second byte data will be executed improperly if the operation is switched to the IDLE state by an

instruction, such as LDW, which executes 2-byte data transfer at a time.

Note 5]: When the IDLE1/2 or SLEEP1 mode is released, SYSCR2 <IDLE> is cleared to "0" automatically.

Note 6]: When the IDLE0 or SLEEP0 mode is released, SYSCR2 <TGHALT> is cleared to "0" automatically.

Note 7]:To Switchthe frequency, first set the new frequency, then turn off the original frequency.

| Internal Clock Control | Register 1 |
|------------------------|------------|
|------------------------|------------|

| FSCTRL<br>(0x0EED) | 7 | 6        | 5       | 4       | 3        | 2   | 1    | 0     |
|--------------------|---|----------|---------|---------|----------|-----|------|-------|
| Bit Symbol         | - | XTAL_SEL | P81_SDR | P80_SDR | PACK_SEL | FOS | CCKS | FSSEL |
| Read/Write         | R | R        | R       | R       | R        | R/W | R/W  | R/W   |
| After reset        | 0 | 0 or 1   | 0 or 1  | 0 or 1  | 0 or 1   | 0   | 1    | 0     |

| XTAL_SEL<br>P81_SDR<br>P80_SDR<br>PACK_SEL | Chip modifying when recording.                  | Do not change the value.(Note 2)                                                                                              |
|--------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| FOSCCKS                                    | Choose internal high-frequency clock (fosc)     | 00: System reserved<br>01: choose internal high-frequency clock 16MHz (default)<br>10: System reserved<br>11: System reserved |
| FSSEL                                      | Choose internal/external-low<br>frequency clock | 0: Choose internal low-frequency clock<br>1: Choose external low-frequency clock                                              |

# Page: 74/ 278

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Note 1) : FOSCCKS/fosc/ internal high frequency/fosc/ default is "01"(16MHz).

Note2] : Bit6~Bit3 is related to chip modifying when record the chip by writer. Please user use "bit operation" for programming. "SET (FSCTRL).0\_1" or "CLR (FSCTRL).0" for example. Do not use other bit to change the value of Bit 6~Bit3.

### Warm-up Counter Control Register

| WUCCR<br>(0x0FCD) | 7      | 6 | 5 | 4 | 3      | 2 | 1      | 0 |
|-------------------|--------|---|---|---|--------|---|--------|---|
| Bit Symbol        | WUCRST | - | - | - | WUCDIV |   | WUCSEL |   |
| Read/Write        | W      | R | R | R | R/W    |   | R/     | W |
| After reset       | 0      | 0 | 0 | 0 | 1      | 1 | 0      | 0 |

| WUCRST | Reset and stop the warm-up counter                                | 0<br>1               | -<br>Clear and stop the counter                                                                                                                              |
|--------|-------------------------------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WUCDIV | Select the frequency division of the warm-up counter source clock | 00<br>01<br>10<br>11 | Sourceclock<br>Sourceclock/2<br>Sourceclock/2 <sup>2</sup><br>Sourceclock/2 <sup>3</sup>                                                                     |
| WUCSEL | Select the warm-up counter source clock                           | 00<br>01<br>10<br>11 | Select the internal high-frequency clock (fosc)<br>Select the external high-frequency clock (fc)<br>Select the external low-frequency clock (fs)<br>Reserved |

Note 1): fosc: Internal high-frequency clock [Hz], fc: External high-frequency clock [Hz], , foscl: internal low-frequency clock [Hz], fcgck: Gear clock [Hz], fs: External low-frequency clock [Hz]

Note 2]: WUCCR <WUCRST> is cleared to "0" automatically, and need not be cleared to "0" after bring set to "1".

Note 3]: Bits 7 to 4 of WUCCR are read as "0".

Note 4]: Before starting the warm-up counter operation, set the source clock and the frequency division rate at WUCCR and set the warm-up time at WUCDR.

### Warm-up Counter Data Register

| WUCDR<br>(0x0FCE) | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------|---|-----------------|---|---|---|---|---|---|
| Bit Symbol        |   | WUCDR           |   |   |   |   |   |   |
| Read/Write        |   | R/W             |   |   |   |   |   |   |
| After reset       | 0 | 0 1 1 0 0 1 1 0 |   |   |   |   |   |   |

WUCDR

Warm-up time setting

Note]: Don't start the warm-up counter operation with WUCDR set at "0x00".

### Page: 75/ 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Clock Gear Control Register |   |   |   |   |   |   |      |       |  |  |
|-----------------------------|---|---|---|---|---|---|------|-------|--|--|
| CGCR<br>(0x0FCF)            | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0     |  |  |
| Bit Symbol                  | - | - | - | - | - | - | FCGC | CKSEL |  |  |
| Read/Write                  | R | R | R | R | R | R | R/W  |       |  |  |
| After reset                 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0     |  |  |
| After reset                 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0     |  |  |

| FCGCKSEL Clock gear setting | 01 | fcgck = fc / 4<br>fcgck = fc / 2<br>fcgck = fc<br>fcgck = fc / 8 |
|-----------------------------|----|------------------------------------------------------------------|
|-----------------------------|----|------------------------------------------------------------------|

Note 1]:fc: High-frequency reference clock [Hz], fcgck: Gear clock [Hz] Note 2]: Don't change CGCR <FCGCKSEL> in the SLOW mode. Note 3]: Bits 7 to 2 of CGCR are read as "0".

# 6.3 Function

# 6.3.1 Clock Generator

The clock generator generates the basic clock for the system clocks to be supplied to the CPU core and peripheral circuits. It contains two oscillation circuits: one for the high-frequency clock and the other for the low-frequency clock.

The oscillation circuit pins are also used as ports P0. For the setting to use them as ports, refer to the chapter of I/O Ports. To use ports P00 and P01 as the high-frequency clock oscillation circuits (the XIN and XOUT pins), set P0FC0 to "1" and then set SYSCR2 <XEN> to "1".

The high-frequency (fc) clock and the low-frequency (fs) clock can easily be obtained by connecting an oscillator between the XIN and XOUT pins.

The software control is executed by SYSCR2 <XEN>, SYSCR2 <XTEN> and the P0 port function control register P0FC. The hardware control is executed by reset release and the operation mode control circuit when the operation is switched to the STOP mode as described in "4.3.1 Operation Mode Control Circuit".

Note): No hardware function is available for external direct monitoring of the basic clock. The oscillation frequency can be adjusted by programming the system to output pulses at a certain frequency to a port (for example, a clock output) with interrupts disabled and the watchdog timer disabled and monitoring the output. An adjustment program must be created in advance for a system that requires adjustment of the oscillation frequency.

To prevent the dead lock of the CPU core due to the software-controlled enabling/disabling of the oscillation, an internal factor reset is generated depending on the combination of values of the clock

# Page: 76 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

selected as the main system clock, SYSCR2 <XEN>, SYSCR2 <XTEN> and the P0 port function control register P0FC0.

| P0FC0      | SYSCR2<br><xen></xen> | SYSCR2<br><xten></xten> | SYSCR2<br><sysck></sysck> | State                                                                                                                                  |
|------------|-----------------------|-------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Don't Care | 0                     | 0                       | Don't Care                | All the oscillation circuits are stopped.                                                                                              |
| Don't Care | Don't Care            | 0                       | 1                         | The low-frequency clock (fs) is selected as the main system<br>clock, but the low-frequency clock oscillation circuit is<br>stopped.   |
| Don't Care | 0                     | Don't Care              | 0                         | The high-frequency clock (fc) is selected as the main system<br>clock, but the high-frequency clock oscillation circuit is<br>stopped. |
| 0          | 1                     | Don't Care              | Don't Care                | The high-frequency clock oscillation circuit is allowed to<br>oscillate, but the port is set as a general-purpose port.                |

### Table 6.1 Prohibited Combinations of Oscillation Enable Register Conditions

Note): It takes a certain period of time after SYSCR2 <SYSCK> is changed before the main system clock is switched. If the currently operating oscillation circuit is stopped before the main system clock is switched, the internal condition becomes as shown in Table 6.1 and a system clock reset occurs. For details of clock switching, refer to "4.3.2 Operation Mode Control".







Note 1) : The appropriate oscillation circuit and providing proper capacitance are necessary for stable clock, these are highly correlated with the circuit board. System must be confirmed stable after all the components on the board is mounted. Note 2) : XIN/XOUT pin has build-in capacitance (6pF each). Load capacitance can be designed according to character of oscillator, accuracy of clock and design of circuit board

# 6.3.2 Clock Gear

The clock gear is a circuit that selects a gear clock (fcgck) obtained by dividing the high-frequency reference clock (fh) and inputs it to the timing generator. Select a divided clock at CGCR <FCGCKSEL>.

# Page: 77 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

Two machine cycles are needed after CGCR <FCGCKSEL> is changed before the gear clock (fcgck) is changed.

| CGCR <fcgcksel></fcgcksel> | fcgck    |
|----------------------------|----------|
| 00                         | fh / 4   |
| 01                         | fh / 2   |
| 10                         | fh       |
| 11                         | Reserved |

### Table 6.2Gear Clock (fcgck)

The gear clock (fcgck) may be longer than the set clock width, immediately after CGCR <FCGCKSEL> is changed. Immediately after reset release, the gear clock (fcgck) becomes the clock that is a quarter of the high-frequency reference clock (fh).

Note): Don't change CGCR <FCGCKSEL> in the SLOW mode. This may stop the gear clock (fcgck) from being changed.

### 6.3.3 Timing Generator

The timing generator is a circuit that generates system clocks to be supplied to the CPU core and the peripheral circuits, from the gear clock (fcgck) or the clock that is a quarter of the low-frequency clock (fs). The timing generator has the following functions:

- 1. Generation of the main system clock (fm)
- 2. Generation of clocks for the timer counter, the time base timer and other peripheral circuits

The timing generator consists of a main system clock generator, a prescaler, a 21-stage divider and a machine cycle counter.





### Page: 78/ 278

## 6.3.3.1 Main System Clock Generator

This circuit selects the gear clock (fcgck) or the clock that is a quarter of the low-frequency clock (fs) for the main system clock (fm) to operate the CPU core.

Clearing SYSCR2 <SYSCK> to "0" selects the gear clock (fcgck). Setting it to "1" selects the clock that is a quarter of the low-frequency clock (fs).

## 6.3.3.2 Prescaler and Divider

These circuits divide fcgck. The divided clocks are supplied to the timer counter, the time base timer and other peripheral circuits.

When both SYSCR1 <DV9CK> and SYSCR2 <SYSCK> are "0", the input clock to stage 9 of the divider becomes the output of stage 8 of the divider.

When SYSCR1 <DV9CK> or SYSCR2 <SYSCK> is "1", the input clock to stage 9 of the divider becomes fs/4. When SYSCR2 <SYSCK> is "1", the outputs of stages 1 to 8 of the divider and prescaler are stopped.

The prescaler and divider are cleared to "0" at a reset and at the end of the warm-up operation that follows the release of STOP mode.

## 6.3.3.3 Machine Cycle

Instruction execution is synchronized with the main system clock (fm).

The minimum instruction execution unit is called a "machine cycle". One machine cycle corresponds to one main system clock.

There are a total of 11 different types of instructions for the i87 Series: 10 types ranging from 1-cycle instructions, which require one machine cycle for execution, to 10-cycle instructions, which require 10 machine cycles for execution, and 13-cycle instructions, which require 13 machine cycles for execution.

# 6.4 Warm-up Counter

The warm-up counter is a circuit that counts the internal high-frequency clock (fosc), the external high-frequency clock (fc) and the external low-frequency clock (fs), and it consists of a source clock selection circuit, a 3-stage frequency division circuit and a 14-stage counter.

The warm-up counter is used to secure the time after a power-on reset is released before the supply voltage becomes stable and secure the time after the STOP mode is released or the operation mode is changed before the oscillation by the oscillation circuit becomes stable.

# Page: 79/ 278

iMQ Technology Inc. No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1



Figure 6.4Warm-up Counter Circuit

# 6.4.1 Warm-up Counter Operation When the Oscillation is Enabled by Hardware

### 6.4.1.1 When a Power-on Reset is Released or a Reset is Released

The warm-up counter serves to secure the time after a power-on reset is released before the supply voltage becomes stable and the time after a reset is released before the oscillation by the high-frequency clock oscillation circuit becomes stable.

When the power is turned on and the supply voltage exceeds the power-on reset release voltage, the warm-up counter reset signal is released. At this time, the CPU and the peripheral circuits are held in the reset state.

A reset signal initializes WUCCR <WUCSEL> to "0" and WUCCR <WUCDIV> to "11", which selects the high-frequency clock (fc) as the input clock to the warm-up counter.

When a reset is released for the warm-up counter, the internal high-frequency clock (fosc) is input to the warm-up counter, and the 14-stage counter starts counting the internal high-frequency clock (fosc).

When the upper 8 bits of the warm-up counter become equal to WUCDR, counting is stopped and a reset is released for the CPU and the peripheral circuits.

WUCDR is initialized to 128 (decimal value) after reset release, which makes the warm-up time  $102 \times 2^{9}$ /fc [s].

Note): The clock output from the oscillation circuit is used as the input clock to the warm-up counter. The warm-up time contains errors because the oscillation frequency is unstable until the oscillation circuit becomes stable.

# Page: 80 / 278

## 6.4.1.2 When the STOP Mode is Released

The warm-up counter serves to secure the time after the oscillation is enabled by the hardware before the oscillation becomes stable at the release of the STOP mode.

The high-frequency clock (fc) or the low-frequency clock (fs), which generates the main system clock when the STOP mode is activated, is selected as the input clock for frequency division circuit, regardless of WUCCR <WUCSEL>.Before the STOP mode is activated, select the division rate of the input clock to the warm-up counter at WUCCR <WUCDIV> and set the warm-up time at WUCDR.

When the STOP mode is released, the 14-stage counter starts counting the input clock selected in the frequency division circuit.

When the upper 8 bits of the warm-up counter become equal to WUCDR, counting is stopped and the operation is restarted by an instruction that follows the STOP mode activation instruction.

| Clock that generated the<br>main system clock when the<br>STOP mode was activated | WUCCR<br><wucsel></wucsel> | WUCCD<br><wucdiv></wucdiv> | Cpunter input<br>clock | Warm-up time                                   |
|-----------------------------------------------------------------------------------|----------------------------|----------------------------|------------------------|------------------------------------------------|
|                                                                                   |                            | 00                         | fosc                   | $2^{6}$ /fosc to 255 × $2^{6}$ /fosc           |
| fore                                                                              | Den't Care                 | 01                         | fosc/2                 | $2^{7}$ /fosc to 255 × $2^{7}$ /fosc           |
| fosc                                                                              | Don't Care                 | 10                         | fosc/2 <sup>2</sup>    | $2^{8}$ /fosc to 255 × $2^{8}$ /fosc           |
|                                                                                   |                            | 11                         | fosc/2 <sup>3</sup>    | $2^{9}$ /fosc to 255 × $2^{9}$ /fosc           |
|                                                                                   | Don't Care                 | 00                         | fc                     | 2 <sup>6</sup> /fc to 255 × 2 <sup>6</sup> /fc |
| 6-                                                                                |                            | 01                         | fc/2                   | $2^{7}$ /fc to 255 × $2^{7}$ /fc               |
| fc                                                                                |                            | 10                         | fc/2 <sup>2</sup>      | 2 <sup>8</sup> /fc to 255 × 2 <sup>8</sup> /fc |
|                                                                                   |                            | 11                         | fc/2 <sup>3</sup>      | 2 <sup>9</sup> /fc to 255 × 2 <sup>9</sup> /fc |
|                                                                                   |                            | 00                         | fs                     | 2 <sup>6</sup> /fs to 255 × 2 <sup>6</sup> /fs |
| fs                                                                                | Daw't Cana                 | 01                         | fs/2                   | $2^{7}$ /fs to 255 × $2^{7}$ /fs               |
|                                                                                   | Don't Care                 | 10                         | fs/2 <sup>2</sup>      | $2^{8}$ /fs to 255 × $2^{8}$ /fs               |
|                                                                                   |                            | 11                         | fs/2 <sup>3</sup>      | $2^{9}$ /fs to 255 × 2 <sup>9</sup> /fs        |

Note 1): When the operation is switched to the STOP mode during the warm-up for the oscillation enabled by the software, the warm-up counter holds the value at the time and restarts counting after the STOP mode is released. In this case, the warm-up time at the release of the STOP mode becomes insufficient. Don't switch the operation to the STOP mode during the warm-up for the oscillation enabled by the software.

Note 2): The clock output from the oscillation circuit is used as the input clock to the warm-up counter. The warm-up time contains errors because the oscillation frequency is unstable until the oscillation circuit becomes stable. Set the sufficient time for the oscillation start property of the oscillator.

# Page: 81/ 278

# 6.4.2 Warm-up Counter Operation When the Oscillation is Enabled by Software

The warm-up counter serves to secure the time after the oscillation is enabled by the software before the oscillation becomes stable, at a mode change from NORMAL1 to NORMAL2 or from SLOW1 to SLOW2.Select the input clock to the frequency division circuit at WUCCR <WUCSEL>. Select the input clock to the 14-stage counter at WUCCR <WUCDIV>.

After the warm-up time is set at WUCDR, setting SYSCR2 <OSCEN>, SYSCR2 <XEN> or SYSCR2 <XTEN> to "1" allows the stopped oscillation circuit to start oscillation and the 14-stage counter to start counting the selected input clock. When the upper 8 bits of the counter become equal to WUCDR, an INTWUC interrupt occurs, counting is stopped and the counter is cleared.

Set WUCCR <WUCRST> to "1" to discontinue the warm-up operation. By setting it to "1", the countup operation is stopped, the warm-up counter is cleared, and WUCCR <WUCRST> is cleared to "0". SYSCR2 <OSCEN>, SYSCR2<XEN> and SYSCR2 <XTEN> hold the values when WUCCR <WUCRST> is set to "1". To restart the warm-up operation, SYSCR2 <OSCEN>, SYSCR2 <XEN> or SYSCR2<XTEN> must be cleared to "0".

| WUCCR<br><wucsel></wucsel> | WUCCR<br><wucdiv></wucdiv> | Counter input<br>clock | Warm-up time                                     |
|----------------------------|----------------------------|------------------------|--------------------------------------------------|
|                            | 00                         | fosc                   | 26 / fosc to 255 x 26 / fosc                     |
| 00                         | 01                         | fosc / 2               | 27 / fosc to 255 x 27 / fosc                     |
| 00                         | 10                         | fosc / 2 <sup>2</sup>  | 28 / fosc to 255 x 28 / fosc                     |
|                            | 11                         | fosc / 2 <sup>3</sup>  | 29 / fosc to 255 x 29 / fosc                     |
|                            | 00                         | fc                     | 26 / fc to 255 x 26 / fc                         |
| 01                         | 01                         | fc / 2                 | 27 / fc to 255 x 27 / fc                         |
| 01                         | 10                         | fc / 2 <sup>2</sup>    | 28 / fc to 255 x 28 / fc                         |
|                            | 11                         | fc / 2 <sup>3</sup>    | 29 / fc to 255 x 29 / fc                         |
|                            | 00                         | fs                     | 2 <sup>6</sup> / fs to 255 x 2 <sup>6</sup> / fs |
| 10                         | 01                         | fs / 2                 | 27 / fs to 255 x 27 / fs                         |
| 10                         | 10                         | fs / 2 <sup>2</sup>    | 2 <sup>8</sup> / fs to 255 x 2 <sup>8</sup> / fs |
|                            | 11                         | fs / 2 <sup>3</sup>    | 2º / fs to 255 x 2º / fs                         |

Note 1): The warm-up counter starts counting when SYSCR2 <OSCEN>, SYSCR2 <XEN> or SYSCR2 <XTEN> is changed from "0" to "1". The counter will not start counting by writing "1" to SYSCR2 <OSCEN>, SYSCR2 <XEN> or SYSCR2 <XTEN> when it is in the state of "1".

Note 2): The clock output from the oscillation circuit is used as the input clock to the warm-up counter. The warm-up time contains errors because the oscillation frequency is unstable until the oscillation circuit becomes stable. Set the sufficient time for the oscillation start property of the oscillator.

## Page: 82 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 7.Interrupts

MQ6812/MQ6821 has a total of 18 interrupt sources excluding reset. Interrupts can be nested with priorities. Three of the internal interrupt sources are non-maskable while the rest are maskable. Interrupt sources are provided with interrupt latches (IL), which hold interrupt requests, and have independent vector addresses. When a request for an interrupt is generated, its interrupt latch is set to "1", which requests the CPU to accept the interrupt. Acceptance of interrupts is enabled or disabled by software using the interrupt master enable flag (IMF) and individual enable flag (EF) for each interrupt source. If multiple maskable interrupts are generated simultaneously, the interrupts are accepted in order of descending priority, as Table 7.1. However, there are no prioritized interrupt sources among non-maskable interrupts.

|                        | Interrupt sources | Enable condition               | Interrupt<br>latch | Vector Address<br>(MCU mode) | Basic priority |
|------------------------|-------------------|--------------------------------|--------------------|------------------------------|----------------|
| Internal/Ex-<br>ternal | (Reset)           | Non-maskable                   | -                  | 0xFFFE                       | 1              |
| Internal               | INTSWI            | Non-maskable                   | -                  | 0xFFFC                       | 2              |
| Internal               | INTUNDEF          | Non-maskable                   | -                  | 0xFFFC                       | 2              |
| Internal               | INTWDT            | Non-maskable                   | ILL <il3></il3>    | 0xFFF8                       | 2              |
| Internal               | INTWUC            | IMF AND EIRL <ef4> = 1</ef4>   | ILL <il4></il4>    | 0xFFF6                       | 5              |
| Internal               | INTTBT            | IMF AND EIRL <ef5> = 1</ef5>   | ILL <il5></il5>    | 0xFFF4                       | 6              |
| Internal               | INTSIO0           | IMF AND EIRL <ef6> = 1</ef6>   | ILL <il6></il6>    | 0xFFF2                       | 7              |
| Internal               | INTVLTD           | IMF AND EIRH <ef9> = 1</ef9>   | ILH <il9></il9>    | 0xFFEC                       | 8              |
| Internal               | INTADC            | IMF AND EIRH <ef10> = 1</ef10> | ILH <il10></il10>  | 0xFFEA                       | 9              |
| Internal               | INTRTC            | IMF AND EIRH <ef11> = 1</ef11> | ILH <il11></il11>  | 0xFFE8                       | 10             |
| Internal               | INTTC00           | IMF AND EIRH <ef12> = 1</ef12> | ILH <il12></il12>  | 0xFFE6                       | 11             |
| Internal               | INTTC01           | IMF AND EIRH <ef13> = 1</ef13> | ILH <il13></il13>  | 0xFFE4                       | 12             |
| Internal               | INTTCA0           | IMF AND EIRH <ef14> = 1</ef14> | ILH <il14></il14>  | 0xFFE2                       | 13             |
| Internal               | INTSBIO           | IMF AND EIRH <ef15> = 1</ef15> | ILH <il15></il15>  | 0xFFE0                       | 14             |
| External               | INT2              | IMF AND EIRE <ef18> = 1</ef18> | ILE <il18></il18>  | 0xFFDA                       | 15             |
| External               | INT3              | IMF AND EIRE <ef19> = 1</ef19> | ILE <il19></il19>  | 0xFFD8                       | 16             |
| External               | INT4              | IMF AND EIRE <ef20> = 1</ef20> | ILE <il20></il20>  | 0xFFD6                       | 17             |
| Internal               | INTRXD1           | IMF AND EIRE <ef22> = 1</ef22> | ILE <il22></il22>  | 0xFFD2                       | 18             |
| Internal               | INTTXD1           | IMF AND EIRE <ef23> = 1</ef23> | ILE <il23></il23>  | 0xFFD0                       | 19             |
| Internal               | INTTC02           | IMF AND EIRD <ef24> = 1</ef24> | ILD <il24></il24>  | 0xFFCE                       | 20             |
| Internal               | INTTC03           | IMF AND EIRD <ef25> = 1</ef25> | ILD <il25></il25>  | 0xFFCC                       | 21             |
| Internal               | INTTC04           | IMF AND EIRD <ef28> = 1</ef28> | ILD <il28></il28>  | 0xFFC6                       | 22             |
| Internal               | INTTC05           | IMF AND EIRD <ef29> = 1</ef29> | ILD <il29></il29>  | 0xFFC4                       | 23             |

### Table 7.1 Interrupt Information Table

Note 1): To use the watchdog timer interrupt (INTWDT), clear WDTCR1<WDTOUT> to "0" (It is set for the "Reset request" after reset is released). For details, see "10.1 Watchdog Timer/ Watchdog Timer 2".

## Page: 83/ 278

# 汉芝电子股份有限公司

iMQ Technology Inc.

### No. : TDDS01-M6812-EN

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1



Figure 7.1 Interrupts Control Scheme

### Page: 84 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 7.1 Interrupts Latches (IL29 to IL3)

An interrupt latch is provided for each interrupt source, except for a software interrupt and an undefined instruction execution interrupt. When an interrupt request is generated, the latch is set to "1", and then the CPU is requested to accept the interrupt if its acceptance is enabled. The interrupt latch is cleared to "0" immediately after the interrupt is accepted. All interrupt latches are initialized to "0" during reset. The interrupt latches are located at addresses 0x0FE0, 0x0FE1, 0x0FE2and 0xFE3 in SFR area. Each latch can be cleared to "0" individually by an instruction. However, IL3 interrupt latches cannot be cleared by instructions.

Do not use any read-modify-write instruction, such as a bit manipulation or operation instruction, because it may clear interrupt requests generated while the instruction is executed.

Interrupt latches cannot be set to "1" by using an instruction. Writing "1" to an interrupt latch is equivalent to deny clearing of the interrupt latch, and not setting the interrupt latch.

Since interrupt latches can be read by instructions, the status of interrupt requests can be monitored by software.

Note): In the main program, before manipulating an interrupt latch (IL), be sure to clear the master enable flag (IMF) to "0" (Disable interrupt by DI instruction). Then set the IMF to "1" as required after operating the IL (Enable interrupt by EI instruction). In the interrupt service routine, the IMF becomes "0" automatically and need not be cleared to "0" normally. However, if using multiple interrupt in the interrupt service routine, manipulate the IL before setting the IMF to "1".

# 7.2 Interrupt Enable Register (EIR)

The interrupt enable register (EIR) enables and disables the acceptance of interrupts, except for the nonmaskable interrupts (software interrupt, undefined instruction interrupt and watchdog interrupt). Nonmaskable interrupts are accepted regardless of the contents of the EIR.

The EIR consists of the interrupt master enable flag (IMF) and the individual interrupt enable flags (EF). These registers are located at addresses 0x003A, 0x003B, 0x003C and 0x003D in the SFR area, and they can be read and written by instructions (including read-modify-write instructions such as bit manipulation or operation instructions).

# 7.3 Interrupt Master Enable Flag (IMF)

The interrupt master enable flag (IMF) enables and disables the acceptance of all maskable interrupts. Clearing the IMF to "0" disables the acceptance of all maskable interrupts. Setting the IMF to "1" enables the acceptance of the interrupts that are specified by the individual interrupt enable flags.

When an interrupt is accepted, the IMF is stacked and then cleared to "0", which temporarily disables the

# Page: 85/ 278

subsequent maskable interrupts. After the interrupt service routine is executed, the stacked data, which was the status before interrupt acceptance, reloads on the IMF by return interrupt instruction [RETI] / [RETN].

The IMF is located on bit 0 in EIRL (Address: 0x003A in SFR), and can be read and written by instructions. The IMF is normally set and cleared by [EI] and [DI] instructions respectively. During reset, the IMF is initialized to "0".

# 7.4 Individual Interrupt Enable Flag (EF29 to EF4)

Each of these flags enables and disables the acceptance of its maskable interrupt. Setting the corresponding bit of an individual interrupt enable flag to "1" enables acceptance of its interrupt, and setting the bit to "0" disables acceptance.

During reset, all the individual interrupt enable flags are initialized to "0" and no maskable interrupts are accepted until the flags are set to "1".

Note): In the main program, before manipulating the interrupt enable flag (EF), be sure to clear the master enable flag (IMF) to "0" (Disable interrupt by DI instruction). Then set the IMF to "1" as required after operating the EF (Enable interrupt by EI instruction). In the interrupt service routine, the IMF becomes "0" automatically and need not be cleared to "0" normally. However, if using multiple interrupt in the interrupt service routine, manipulate the EF before setting the IMF to "1".

| ILL<br>(0x0FE0) | 7 | 6       | 5      | 4      | 3      | 2 | 1 | 0 |
|-----------------|---|---------|--------|--------|--------|---|---|---|
| Bit Symbol      | - | IL6     | IL5    | IL4    | IL3    | - | - | - |
| Read/Write      | R | R/W     | R/W    | R/W    | R      | R | R | R |
| After reset     | 0 | 0       | 0      | 0      | 0      | 0 | 0 | 0 |
| Function        | - | INTSIO0 | INTTBT | INTWUC | INTWDT | - | - | - |

### Interrupt Latch (ILL)

## Interrupt Latch (ILH)

| ILH<br>(0x0FE1) | 7      | 6       | 5       | 4       | 3      | 2      | 1      | 0 |
|-----------------|--------|---------|---------|---------|--------|--------|--------|---|
| Bit Symbol      | IL15   | IL14    | IL13    | IL12    | IL11   | IL10   | IL9    | - |
| Read/Write      | R/W    | R/W     | R/W     | R/W     | R/W    | R/W    | R/W    | R |
| After reset     | 0      | 0       | 0       | 0       | 0      | 0      | 0      | 0 |
| Function        | INTSBI | INTTCA0 | INTTC01 | INTTC00 | INTRTC | INTADC | INTLVD | - |

### Interrupt Latch (ILE)

| ILE<br>(0x0FE2) | 7    | 6    | 5 | 4    | 3    | 2    | 1 | 0 |
|-----------------|------|------|---|------|------|------|---|---|
| Bit Symbol      | IL23 | IL22 | - | IL20 | IL19 | IL18 | - | - |
| Read/Write      | R/W  | R/W  | R | R/W  | R/W  | R/W  | R | R |
| After reset     | 0    | 0    | 0 | 0    | 0    | 0    | 0 | 0 |

# Page: 86/ 278

# 汉芝电子股份有限公司

| iMQ Tech  | nology Inc. |         |         |           |          |          |           |     |         |        |
|-----------|-------------|---------|---------|-----------|----------|----------|-----------|-----|---------|--------|
| No. : TDD | S01-M6812-E | EN .    | Nar     | ne : MQ68 | 812/MQ68 | 821/MQ68 | 22 Datash | eet | Version | : V1.1 |
|           |             |         |         |           |          |          |           |     |         | 1      |
|           | Function    | INTTXD1 | INTRXD1 | -         | INT4     | INT3     | INT2      | -   | -       |        |

### Interrupt Latch (ILD)

| ILD<br>(0x0FE3) | 7 | 6 | 5       | 4       | 3 | 2 | 1       | 0       |
|-----------------|---|---|---------|---------|---|---|---------|---------|
| Bit Symbol      | - | - | IL29    | IL28    | - | - | IL25    | IL24    |
| Read/Write      | R | R | R/W     | R/W     | R | R | R/W     | R/W     |
| After reset     | 0 | 0 | 0       | 0       | 0 | 0 | 0       | 0       |
| Function        | - | - | INTTC05 | INTTC04 | - | - | INTTC03 | INTTC02 |

|             |           |        | Read                                      | Write                                                                          |
|-------------|-----------|--------|-------------------------------------------|--------------------------------------------------------------------------------|
| IL29 to IL4 | Interrupt | 0      | No interrupt request                      | Clear the interrupt request<br>(Notes 2 and 3)                                 |
|             | latch     | 1      | Interrupt request                         | Does not clear the interrupt request<br>( Interrupt is not set by writing "1") |
| IL3         |           | 0<br>1 | No interrupt request<br>Interrupt request | -                                                                              |

Note 1):IL3 is a read-only register. Writing the register does not affect interrupt latch.

Note 2]: In the main program, before manipulating an interrupt latch (IL), be sure to clear the interrupt master enable flag (IMF) to"0" (Disable interrupt by DI instruction). Then set the IMF to "1" as required after operating the IL (Enable interrupt by El instruction). In the interrupt service routine, the IMF becomes "0" automatically and need not be cleared to "0" normally. However, ifusing multiple interrupt in the interrupt service routine, manipulate the IL before setting the IMF to "1".

Note 3]: Do not clear IL with read-modify-write instructions such as bit operations.

Note 4]: When a read instruction is executed on ILL, bits 0 to 2 are read as "0". Other unused bits are read as "0".

| <br>terrupt Errab | ie Register |         |        |        |   |   |   |     |
|-------------------|-------------|---------|--------|--------|---|---|---|-----|
| EIRL<br>(0x003A)  | 7           | 6       | 5      | 4      | 3 | 2 | 1 | 0   |
| Bit Symbol        | -           | EF6     | EF5    | EF4    | - | - | - | IMF |
| Read/Write        | R           | R/W     | R/W    | R/W    | R | R | R | R/W |
| After reset       | 0           | 0       | 0      | 0      | 0 | 0 | 0 | 0   |
| Function          | -           | INTSIO0 | INTTBT | INTWUC | - | - | - | IMF |

### Interrupt Enable Register (EIRL)

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

### Interrupt Enable Register (EIRH)

| EIRH<br>(0x003B) | 7      | 6       | 5       | 4       | 3      | 2      | 1      | 0 |
|------------------|--------|---------|---------|---------|--------|--------|--------|---|
| Bit Symbol       | EF15   | EF14    | EF13    | EF12    | EF11   | EF10   | EF9    | - |
| Read/Write       | R/W    | R/W     | R/W     | R/W     | R/W    | R/W    | R/W    | R |
| After reset      | 0      | 0       | 0       | 0       | 0      | 0      | 0      | 0 |
| Function         | INTSBI | INTTCA0 | INTTC01 | INTTC00 | INTRTC | INTADC | INTLVD | - |

### Interrupt Enable Register (EIRE)

| EIRE<br>(0x003C) | 7       | 6       | 5 | 4    | 3    | 2    | 1 | 0 |
|------------------|---------|---------|---|------|------|------|---|---|
| Bit Symbol       | EF23    | EF22    | - | EF20 | EF19 | EF18 | - | - |
| Read/Write       | R/W     | R/W     | R | R/W  | R/W  | R/W  | R | R |
| After reset      | 0       | 0       | 0 | 0    | 0    | 0    | 0 | 0 |
| Function         | INTTXD1 | INTRXD1 | - | INT4 | INT3 | INT2 | - | - |

### Interrupt Enable Register (EIRD)

| EIRD<br>(0x003D) | 7 | 6 | 5       | 4       | 3 | 2 | 1       | 0       |
|------------------|---|---|---------|---------|---|---|---------|---------|
| Bit Symbol       | - | - | EF29    | EF28    | - | - | EF25    | EF24    |
| Read/Write       | R | R | R/W     | R/W     | R | R | R/W     | R/W     |
| After reset      | 0 | 0 | 0       | 0       | 0 | 0 | 0       | 0       |
| Function         | - | - | INTTC05 | INTTC04 | - | - | INTTC03 | INTTC02 |

| EF29 to EF4 | EF29 to EF4 Individual Interrupt Enable Flag<br>(specified for each bit) |        | Disable the acceptance of each maskable interrupt<br>Enable the acceptance of each maskable interrupt |
|-------------|--------------------------------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------|
| IMF         | Interrupt Master Enable Flag                                             | 0<br>1 | Disable the acceptance of all maskable interrupts<br>Enable the acceptance of all maskable interrupts |

Note 1): Do not set the IMF and the interrupt enable flag (EF15 to EF4) to "1" at the same time.

Note 2]: In the main program, before manipulating the interrupt enable flag (EF), be sure to clear the master enable flag (IMF) to "0" (Disable interrupt by DI instruction). Then set the IMF to "1" as required after operating the EF (Enable interrupt by EI instruction). In the interrupt service routine, the IMF becomes "0" automatically and need not be cleared to "0" normally. However, if using multiple interrupt in the interrupt service routine, manipulate the EF before setting the IMF to "1".

Note 3]:When a read instruction is executed on EIRL, bits 3 to 1 are read as "0". Other unused bits are read as "0".

# 7.5 External Interrupt Control Circuit

External interrupts detects the change of the input signal and generates an interrupt request. Noise can be removed by the built-in digital noise canceller.

# 7.5.1 Configuration

The external interrupt control circuit consists of a noise canceller, an edge detection circuit, a level detection circuit and an interrupt signal generation circuit.

Externally input signals are input to the rising edge or falling edge or level detection circuit for each external interrupt, after noise is removed by the noise canceller.



Figure 7.3 External Interrupts 2/3/4

Page: 89/ 278

### Name : MQ6812/MQ6821/MQ6822 Datasheet

## 7.5.2 Control

External interrupts are controlled by the following registers:

### Low Power Consumption Register 3

| POFFCR3<br>(0x0F77) | 7 | 6 | 5 | 4      | 3      | 2      | 1 | 0 |
|---------------------|---|---|---|--------|--------|--------|---|---|
| Bit Symbol          | - | - | - | INT4EN | INT3EN | INT2EN | - | - |
| Read/Write          | R | R | R | R/W    | R/W    | R/W    | R | R |
| After reset         | 0 | 0 | 0 | 0      | 0      | 0      | 0 | 0 |

| INT4EN | INT4 Control | 0<br>1 | Disable<br>Enable |
|--------|--------------|--------|-------------------|
| INT3EN | INT3 Control | 0<br>1 | Disable<br>Enable |
| INT2EN | INT2 Control | 0<br>1 | Disable<br>Enable |

Note 1): Clearing INTxEN |x=2 to 4) to "0" stops the clock supply to the external interrupts. This invalidates the data written in the control register for each external interrupt. When using the external interrupts, set INTxEN to "1" and then write data into the control register for each external interrupt.

Note 2]: Interrupt request signals may be generated when INTXEN is changed. Before changing INTXEN, clear the corresponding interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL1/2 or IDLE1/2 to SLOW1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed and clear the interrupt latch.

Note 3):Bits 7 ~Bit 5 and Bit 1 ~Bit0 of POFFSET3 are read as "0".

| EINTCR2<br>(0x0FD9) | 7 | 6 | 5 | 4       | 3      | 3 2 |        | 0 |
|---------------------|---|---|---|---------|--------|-----|--------|---|
| Bit Symbol          | - | - | - | INT2LVL | INT2ES |     | INT2NC |   |
| Read/Write          | R | R | R | R       | R/W    |     | R/W    |   |
| After reset         | 0 | 0 | 0 | 0       | (      | )   | 0      |   |

### External Interrupt Control Register 2

| INT2LVL | Noise canceller pass signal level when the<br>interrupt request signal is generated for<br>external interrupt 2 | 0: Initial state or signal level "L"<br>1: Signal level "H"                                                                                                                                                                                                                                                                                 |  |  |  |
|---------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| INT2ES  | Select the interrupt request generating condition for external interrupt 2                                      | <ul> <li>00: An interrupt request is generated at the rising edge of the noise canceller pass signal</li> <li>01: An interrupt request is generated at the falling edge of the noise canceller pass signal</li> <li>10: An interrupt request is generated at both edges of the noise canceller pass signal</li> <li>11: Reserved</li> </ul> |  |  |  |

## Page: 90 / 278

# 汉芝电子股份有限公司 iMO Technology Inc.

No. : TDDS01-M6812-EN

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

|        |                                                                    | Normal 1/2, IDLE 1/2                                                                                                    | SLOW 1/2, SLEEP1                                                 |
|--------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| INT2NC | Set the noise canceller sampling interval for external interrupt 1 | 00: fcgck [Hz]<br>01: fcgck / 2 <sup>2</sup> [Hz]<br>10: fcgck / 2 <sup>3</sup> [Hz]<br>11: fcgck / 2 <sup>4</sup> [Hz] | 00: fs/4 [Hz]<br>01: fs/4 [Hz]<br>10: fs/4 [Hz]<br>11: fs/4 [Hz] |

Note 1: fcgck: Gear clock [Hz], fs: Low-frequency clock [Hz]

Note 2: Interrupt requests may be generated during transition of the operation mode. Before changing the operation mode, clear the corresponding interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL1/2 or IDLE1/2 to SLOW1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW1/2 or SLEEP1 to NORMAL1/ 2 or IDLE1/2, wait 2/fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch. Note 3: Interrupt requests may be generated when EINTCR2 is changed. Before doing such operation, clear the corresponding

interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL 1/ 2 or IDLE 1/2 to SLOW 1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW 1/2 or SLEEP1 to NORMAL 1/2 or IDLE 1/2, wait 2/ fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch. Note 4: Bits 7 to 5 of EINTCR2 are read as "0".

| EINTCR3<br>(0x0FDA) | 7 | 6 | 5 | 4       | 3      | 3 2 |        | 0 |
|---------------------|---|---|---|---------|--------|-----|--------|---|
| Bit Symbol          | - | - | - | INT3LVL | INT3ES |     | INT3NC |   |
| Read/Write          | R | R | R | R       | R/W    |     | R/     | W |
| After reset         | 0 | 0 | 0 | 0       | 0      |     | 0      |   |

### External Interrupt Control Register 3

| INT3LVL | Noise canceller pass signal level when the<br>interrupt request signal is generated for<br>external interrupt 3 | 0: Initial state or signal level "L"<br>1: Signal level "H"                                                                                                                                                                                                                                                                                 |                                                                                      |  |  |
|---------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|
| INT3ES  | Select the interrupt request generating condition for external interrupt 3                                      | <ul> <li>00: An interrupt request is generated at the rising edge of the noise canceller pass signal</li> <li>01: An interrupt request is generated at the falling edge of the noise canceller pass signal</li> <li>10: An interrupt request is generated at both edges of the noise canceller pass signal</li> <li>11: Reserved</li> </ul> |                                                                                      |  |  |
| INT3NC  | Set the noise canceller sampling interval for external interrupt 3                                              | NORMAL 1/2, IDLE 1/2<br>00: fcgck [Hz]<br>01: fcgck / 2 <sup>2</sup> [Hz]<br>10: fcgck / 2 <sup>3</sup> [Hz]<br>11: fcgck / 2 <sup>4</sup> [Hz]                                                                                                                                                                                             | SLOW 1/2, SLEEP1<br>00: fs/4 [Hz]<br>01: fs/4 [Hz]<br>10: fs/4 [Hz]<br>11: fs/4 [Hz] |  |  |

Note 1: fcgck: Gear clock [Hz], fs: Low-frequency clock [Hz]

# Page: 91/ 278

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Note 2: Interrupt requests may be generated during transition of the operation mode. Before changing the operation mode, clear the corresponding interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL1/2 or IDLE1/2 to SLOW1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW1/2 or SLEEP1 to NORMAL1/ 2 or IDLE1/2, wait 2/fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch.

Note 3: Interrupt requests may be generated when EINTCR3 is changed. Before doing such operation, clear the corresponding

*interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL1/ 2 or IDLE1/2 to SLOW1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW1/2 or SLEEP1 to NORMAL1/2 or IDLE1/2, wait 2/ fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch.* 

Note 4: Bits 7 to 5 of EINTCR3 are read as "0".

| EINTCR4<br>(0x0FDB) | 7 | 6 | 5 | 4       | 3      | 2 | 1      | 0 |
|---------------------|---|---|---|---------|--------|---|--------|---|
| Bit Symbol          | - | - | - | INT4LVL | INT4ES |   | INT4NC |   |
| Read/Write          | R | R | R | R       | R/W    |   | R/W    |   |
| After reset         | 0 | 0 | 0 | 0       | 0 0    |   | )      |   |

### **External Interrupt Control Register 4**

| INT4LVL | Noise canceller pass signal level when the<br>interrupt request signal is generated for<br>external interrupt 4 | 0: Initial state or signal level "L"<br>1: Signal level "H"                                                                                     |                                                                                      |  |
|---------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| INT4ES  | Select the interrupt request generating condition for external interrupt 4                                      | of the noise canceller pass<br>01: An interrupt request<br>edge of the noise canceller                                                          | is generated at the falling<br>r pass signal<br>generated at both edges of           |  |
| INT4NC  | Set the noise canceller sampling interval for external interrupt 4                                              | NORMAL 1/2, IDLE 1/2<br>00: fcgck [Hz]<br>01: fcgck / 2 <sup>2</sup> [Hz]<br>10: fcgck / 2 <sup>3</sup> [Hz]<br>11: fcgck / 2 <sup>4</sup> [Hz] | SLOW 1/2, SLEEP1<br>00: fs/4 [Hz]<br>01: fs/4 [Hz]<br>10: fs/4 [Hz]<br>11: fs/4 [Hz] |  |

Note 1: fcgck: Gear clock [Hz], fs: Low-frequency clock [Hz]

Note 2: Interrupt requests may be generated during transition of the operation mode. Before changing the operation mode, clear the corresponding interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL1/2 or IDLE1/2 to SLOW1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW1/2 or SLEEP1 to NORMAL1/ 2 or IDLE1/2, wait 2/fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch.

Note 3: Interrupt requests may be generated when EINTCR4 is changed. Before doing such operation, clear the corresponding

interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL 1/

### Page: 92/ 278

2 or IDLE 1/2 to SLOW 1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW 1/2 or SLEEP1 to NORMAL 1/2 or IDLE 1/2, wait 2/ fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch. Note 4: The contents of EINTCRx<INTxLVL> are updated each time an interrupt request signal is generated. Note 5: Bits 7 to 5 of EINTCR4 are read as "0".

# 7.5.3 Function

The condition for generating interrupt request signals and the noise cancel time can be set for external interrupts 2 to 4.

|            |      | Enable          | Interrupt request                                      | External interrupt pin input signal width and noise removal                                                                                                        |                                                                                                                                  |  |  |
|------------|------|-----------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|
| Source Pin | Pin  | Conditions      | signal generated                                       | Normal 1/2,IDLE 1/2                                                                                                                                                | SLOW 1/2, SLEEP 1                                                                                                                |  |  |
| INT2       | INT2 | IMF=1<br>EF18=1 | Falling edge<br>Rising edge<br>Both edges              | Less than 2/fspl: Noise<br>More than 2/fspl and less than<br>3/fspl+1/fcgck: Indeterminate                                                                         | Less than 4/fs: Noise<br>More than 4/fs and less than<br>8/fs: Indeterminate                                                     |  |  |
| INT3       | INT3 | IMF=1<br>EF19=1 | Falling edge<br>Rising edge<br>Both edges              | More than 3/fspl+1/fcgck: Signal<br>Less than 2/fspl: Noise<br>More than 2/fspl and less than<br>3/fspl+1/fcgck: Indeterminate<br>More than 3/fspl+1/fcgck: Signal | More than 8/fs: Signal<br>Less than 4/fs: Noise<br>More than 4/fs and less than<br>8/fs: Indeterminate<br>More than 8/fs: Signal |  |  |
| INT4       | INT4 | IMF=1<br>EF20=1 | Falling edge<br>Rising edge<br>Both edges<br>"H" level | Less than 2/fspl: Noise<br>More than 2/fspl and less than<br>3/fspl+1/fcgck: Indeterminate<br>More than 3/fspl+1/fcgck: Signal                                     | Less than 4/fs: Noise<br>More than 4/fs and less than<br>8/fs: Indeterminate<br>More than 8/fs: Signal                           |  |  |

### Table 7.2 External Interrupts

Note): fcgck: Gear clock [Hz]; fs: Low frequency clock [Hz]; fspl: Sampling interval [Hz]

## 7.5.3.1 Low Power Consumption Function

External interrupts have a function that saves power by using the low power consumption register (POFFCR3) when they are not used. Setting POFFCR3<INTxEN> to "0" stops (disables) the basic clock for external interrupts and helps save power. Note that this makes external interrupts unavailable. Setting POFFCR3<INTxEN> to "1" supplies (enables) the basic clock for external interrupts available.

After reset, POFFCR3<INTxEN> is initialized to "0" and external interrupts become unavailable. When using the external interrupt function for the first time, be sure to set POFFCR3<INTxEN> to "1" in the initial setting of software (before operating the external interrupt control registers).

Note): Interrupt request signals may be generated when INTxEN is changed. Before changing INTxEN, clear the corresponding interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed

# Page: 93/ 278

from NORMAL1/2 or IDLE1/2 to SLOW1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW1/2 or SLEEP1 to NORMAL1/2 or IDLE1/2, wait 2/fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch.

## 7.5.3.2 External Interrupt 2 to 4

### External interrupt 2/3/4

External interrupt 2/3/4 detects the falling edge, the rising edge, both edges or "H" level of the INTx pin and generates interrupt request signals.

### (a) Interrupt Request Signal Generating Condition Detection Function

Select an interrupt request signal generating condition at EINTCRx<INTxES> for external interrupt 2/3/4.

| EINTCRx <intxes></intxes> | Detectedat          |  |  |
|---------------------------|---------------------|--|--|
| 00                        | Rising edge         |  |  |
| 01                        | Falling edge        |  |  |
| 10                        | Both edges          |  |  |
| 11                        | "H" level interrupt |  |  |

Table 7.3Selection of Interrupt Request Generation Edge

(b) A Noise Canceller Pass Signal Monitoring Function when Interrupt Request Signals Generated



### Figure 7.4 Interrupt Request Generation and EINTCRx<INTxLVL> (x = 4)

Page: 94 / 278

The level of a signal that has passed through the noise canceller when an interrupt request is generated can be read by using EINTCRx <INTxLVL>. When both edges are selected as detection edges, the edge where an interrupt is generated can be detected by reading EINTCRx <INTxLVL>.

### (c) Noise Cancel Time Selection Function

In NORMAL1/2 or IDLE1/2 mode, a signal that has been sampled by fcgck is sampled at the sampling interval selected at EINTCRx<INTxNC>. If the same level is detected three consecutive times, the signal is recognized as a signal. If not, the signal is removed as noise.

| EINTCRx <intxes></intxes> | Sampling Interval    |
|---------------------------|----------------------|
| 00                        | fcgck                |
| 01                        | fcgck/2 <sup>2</sup> |
| 10                        | fcgck/2 <sup>3</sup> |
| 11                        | fcgck/2 <sup>4</sup> |

Table 7.4Noise Canceller Sampling Clock



### Figure 7.5 Noise Cancel Operation(x=4)

In SLOW1/2 or SLEEP1 mode, a signal is sampled by the low frequency clock divided by 4. If the same level is detected twice consecutively, the signal is recognized as a signal.

In IDLE0, SLEEP0 or STOP mode, the noise canceller sampling operation is stopped and an external interrupts are unavailable. When operation returns to NORMAL1/2, IDLE1/2, SLOW1/2 or SLEEP1 mode, sampling operation restarts.

Note 1): When noise is input consecutively during sampling external interrupt pins, the noise cancel function does not work properly. Set EINTCRx <INTxNC> according to the cycle of externally input noise.

Note 2]: When an external interrupt pin is used as an output port, the input signal to the port is fixed to "L" when

the mode is switched to the output mode, and thus an interrupt request occurs. To use the pin as an output port,

clear the corresponding interrupt enable register to "0" to disable the generation of interrupt.

Note 3]: Interrupt requests may be generated during transition of the operation mode. Before changing the operation mode, clear the corresponding interrupt enable register to "0" to disable the generation of interrupt. When the operation mode is changed from NORMAL1/2 or IDLE1/2 to SLOW1/2 or SLEEP1, wait 12/fs [s] after the operation mode is changed and clear the interrupt latch. And when the operation mode is changed from SLOW1/2 or SLEEP1 to NORMAL1/2 or IDLE1/2, wait 2/ fcgck+3/fspl [s] after the operation mode is changed and clear the interrupt latch.

# Page: 95/ 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 8. I/O Ports

MQ6812/MQ6821 has 7 parallel input / output ports (max. 28 I/O pins and 2 input pins) as follows:

| Port<br>Name | Pin<br>Name | No. of Pins | Input/output                            | Secondary Functions                                                                                                                                             |
|--------------|-------------|-------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port P0      | P01 to P00  | 2           | Input / Output                          | Also used as the high-frequency oscillator connection pin<br>and the low-frequency oscillator connection pin                                                    |
| Port P1      | P10         | 1           | Input / Output                          | Also used as the external reset input, the external interrupt<br>input and the STOP mode release signal input                                                   |
| Port P2      | P27to P23   | 5           | Input / Output                          | Also used as the UART input/output, the I2C input/output ,<br>LCD driving pin, and the external interrupt input.                                                |
| Port P4      | P47 to P40  | 8           | Input / Output                          | Also used as the analog input , LCD pin, and the external interrupt.                                                                                            |
| Port P7      | P77 to P70  | 8           | Input / Output                          | Also used as the timer counter input/output, DVO output,<br>LCD pin ,SIO input/output, the analog input , the external<br>interrupt and the key-on wakeup input |
| Port P8      | P83 to P80  | 4           | Input / Output<br>(P80/P81:outp<br>our) | Also used as the timer counter input/output, LCD pin, and<br>LED high driving pin (P80/P81).                                                                    |
| Port P9      | P91 to P90  | 2           | Input / Output                          | Also used as the UART input/output                                                                                                                              |
| Port PB      | PB7 to PB4  | 4           | Input / Output                          | Also used as the UART input/output and the LCD pin.                                                                                                             |

### Table 8.1List of I/O Ports



### Figure8.1 Input / Output Timing (Example)

Page: 96 / 278

| 汉芝电子股份有限公司<br>iMO Technology Inc. |                                       |                |
|-----------------------------------|---------------------------------------|----------------|
| No. : TDDS01-M6812-EN             | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

Each output port contains a latch, which holds the output data. No input port has a latch, so the external input data should be externally held until the input data is read from outside or reading should be performed several times before processing. Figure 8.1 shows input / output timing examples.

External data is read from an I/O port in the read cycle during execution of the read instruction. This timing cannot be recognized from outside, so that transient input such as chattering must be processed by the program. Data is output to an I/O port in the next cycle of the write cycle during execution of the write instruction.

# 8.1 I/O Port Control Registers

The following control registers are used for I/O ports. (The port number is indicated in place of x.) Registers that can be set vary depending on the port. For details, refer to the description of each port.

### **PxDR Register**

This is the register for setting output data. When a port is set to the "output mode", the value specified at PxDR is output from the port.

### **PxPRD** Register

This is the register for reading input data. When a port is set to the "input mode", the current port input status can be read by reading PxPRD.

### **PxCR Register**

This register switches a port between input and output. A port can be switched between the "input mode" and the "output mode".

### **PxFC Register**

This register enables the secondary function output of each port. The secondary function output of each port can be enabled or disabled.

### **PxPU** Register

This register determines whether or not the built-in pull-up resistor is connected when a port is used in the input mode.

### **PxPD** Register

This register determines whether or not the built-in pull-down resistor is connected when a port is used in the input mode.

# Page: 97 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

### 8.2 List of I/O Ports Settings

For the setting methods for individual I/O ports, refer to the following table.

| Port Name | Pin Name    | Function                       | Register Set Value |                  |                                                  |  |  |
|-----------|-------------|--------------------------------|--------------------|------------------|--------------------------------------------------|--|--|
| Fort Name | FILLINGILLE | Function                       | PxCR               | PxFC             | Other Required Settings                          |  |  |
|           |             | Port input                     | 0                  | 0                |                                                  |  |  |
|           | P01 to P00  | Port output                    | 1                  | 0                |                                                  |  |  |
| Port P0   | P01         | XOUT                           | *                  | Without register |                                                  |  |  |
|           | P00         | XIN                            |                    | 1                |                                                  |  |  |
| Port P1   | P10         | Port input                     | 0                  |                  | Note 1                                           |  |  |
|           | P10         | Port output                    | 1                  | Without register | Note 1                                           |  |  |
|           | P10         | RESETB input                   | *                  |                  | Note 1                                           |  |  |
|           |             | Port input                     | 0                  | *                |                                                  |  |  |
|           | P27 to P23  | Port output                    | 1                  | 0                |                                                  |  |  |
|           | P27 to P24  | <u>KWI</u> 11 to <u>KWI</u> 8  | *                  | *                | KWUCR2                                           |  |  |
| Port P2   | P27 to P25  | SEG2 to SEG0 output            | 0                  | 0                | P2PU <x> = "0", x = 7~5<br/>LCDCR3 (Note 3)</x>  |  |  |
|           | P24 to P23  | COM7 to COM6 output            | 0                  | 0                | P2PU <x> = "0", x = 4, 3<br/>LCDCR5 (Note 3)</x> |  |  |
|           |             | I2C pin SCL/SDA                | 1                  | 1                |                                                  |  |  |
|           |             | Port input                     | 0                  | *                |                                                  |  |  |
|           | P47 to P40  | Port output                    | 1                  | 0                |                                                  |  |  |
|           |             | <u>KWI</u> 7 to <u>KWI</u> 4   | *                  | *                | KWUCR1                                           |  |  |
| Port 4    |             | <u>KWI</u> 3 to <u>KWI</u> 0   | *                  | *                | KWUCRO                                           |  |  |
|           |             | AIN7 to AIN0                   | 0                  | 1                |                                                  |  |  |
|           | P47 to P44  | SEG11 to SEG8 output           | 0                  | 0                | P4PU <x> = "0", x = 7~4<br/>LCDCR4 (note 3)</x>  |  |  |
|           | P43         | VREF input                     | 0                  | 1                |                                                  |  |  |
|           |             | Port input                     | 0                  | *                |                                                  |  |  |
|           | P77 to P70  | Port output                    | 1                  | 0                |                                                  |  |  |
|           | P76 to P73  | <u>KWI</u> 15 to <u>KWI</u> 12 | *                  | *                | KWUCR3                                           |  |  |
| Port P7   | P77 to P74  | SEG3,SEG6,SEG4,SEG7            | 0                  | 0                | P7PU <x> = "0", x = 7~4<br/>LCDCR3 (not 3)</x>   |  |  |
|           |             | INT4 input                     | 0                  | Without register |                                                  |  |  |
|           | P77         | SIO, SS input                  | 0                  | *                |                                                  |  |  |
|           |             | SIO, SS output                 | 1                  | 1                |                                                  |  |  |

汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Port Name | Pin Name    | Function        | Register Set Value |                     |                                                  |  |  |
|-----------|-------------|-----------------|--------------------|---------------------|--------------------------------------------------|--|--|
| Fort Name | FILLINGILLE | Function        | PxCR               | PxFC                | Other Required Settings                          |  |  |
|           |             | INT3 input      | 0                  | Without register    | Note 1                                           |  |  |
|           | P76         | SIO, SCLK input | 0                  | *                   | Note 1                                           |  |  |
|           |             | SIO,SCLK output | 1                  | 1                   | Note 1                                           |  |  |
|           | P75 -       | INT2 input      | 0                  | Without<br>register |                                                  |  |  |
|           | 175         | SIO,SO input    | 0                  | *                   |                                                  |  |  |
|           |             | DVO output      | 1                  | 1                   |                                                  |  |  |
| Port P7   | P74         | AIN8            | 0                  | 1                   |                                                  |  |  |
|           |             | SIP,SI output   | 1                  | 1                   |                                                  |  |  |
|           |             | TCA0 input      | 0                  | *                   |                                                  |  |  |
|           | P72         | PPGA0B output   | 1                  | 1                   |                                                  |  |  |
|           | P7 1        | PPG01B output   | 1                  | 1                   |                                                  |  |  |
|           |             | PPG00B输出        | 1                  | 1                   |                                                  |  |  |
|           | P70         | SEG5            | 0                  | 0                   | P7PU <0> = "0"<br>LCDCR3 (note 3)                |  |  |
|           | P83 to P80  | Port input      | 0                  | *                   |                                                  |  |  |
|           | P83 to P82  | Port output     | 1                  | 0                   |                                                  |  |  |
|           | P83 to P82  | COM5 to COM4    | 0                  | 0                   | P8PU <x> = "0", x = 3, 2<br/>LCDCR5 (note 3)</x> |  |  |
| Port P8   | P83         | PPG05B output   | 1                  | 1                   |                                                  |  |  |
|           | P82         | PPG04B output   | 1                  | 1                   |                                                  |  |  |
|           | P81         | PPG03B output   | 1                  | 1                   |                                                  |  |  |
|           | P80         | PPG02B output   | 1                  | 1                   |                                                  |  |  |
|           |             | Port input      | 0                  | *                   |                                                  |  |  |
|           | P91 to P90  | Port output     | 1                  | 0                   |                                                  |  |  |
|           |             | COM1 to COM0    | 0                  | 0                   | P9PU <x> = "0", x = 1, 0<br/>LCDCR5 (note 3)</x> |  |  |
| Port P9   | DO 1        | RXD1 input      | 0                  | 0                   | UATCNG <uat1io>="0"</uat1io>                     |  |  |
|           | P91         | TXD1 output     | 1                  | 1                   | UATCNG <uat1io>="1"</uat1io>                     |  |  |
|           | PCO         | TXD1output      | 1                  | 1                   | UATCNG <uat1io>="0"</uat1io>                     |  |  |
|           | P90         | RXD1input       | 0                  | 0                   | UATCNG <uat1io>="1"</uat1io>                     |  |  |

### Table 8.2List of I/O Port Settings

Note 1]: After the power is turned on, pin P10 serves as an external reset input. To use pin P10 as a port, refer to "How to use

### Name : MQ6812/MQ6821/MQ6822 Datasheet

the external reset input pin as a port" of "5.1 Reset Control Circuit".

Note 2): The symbol and numeric characters in the table have the following meanings:

| Symbol and<br>numeric | Meaning                                                              |
|-----------------------|----------------------------------------------------------------------|
| 0                     | Set "0"                                                              |
| 1                     | Set "1"                                                              |
| *                     | Don't care<br>(Operation is the same whether "1" or "0" is selected) |
| Without register      | There is no register that corresponds to the bit                     |

Note 3]: When use LCD function, set "POFFCR2<LCDEN >=1" and "LCDCR1<EDSP>=1", and the PxPU register have to set "0".Detail please refer "11. LCD " chapter.

# 8.3 I/O Port Control Register 8.3.1 Port P0 (P01 to P00) Register

Port P0 is a 2-bit input / output port that can be set to input or output for each bit individually, and it is also used as the high-frequency external crystal connection pin and the low-frequency external crystal connection pin.

Port P0 contains a programmable pull-up resistor on the VDD side. This pull-up resistor can be used when the port is used in the input mode.

| Port Name             | P01  | P00 |
|-----------------------|------|-----|
| Secondary<br>function | XOUT | XIN |

### Table 8.3 Port P0

### Port P0 Output Latch Register

| P0DR<br>(0x0000      |    | 7 | 6 | 5 | 4 | 3 | 2 | 1                            | 0   |
|----------------------|----|---|---|---|---|---|---|------------------------------|-----|
| Bit Symbo            | ol | - | - | - | - | - | - | P01                          | P00 |
| Read/Wri             | te | R | R | R | R | R | R | R/W                          | R/W |
| After rese           | et | 0 | 0 | 0 | 0 | 0 | 0 | 0 0                          |     |
| 0:<br>Function<br>1: |    |   |   |   |   |   |   | Outputs L lev<br>output mode |     |
|                      |    |   |   |   |   |   |   | Outputs H lev<br>output mode |     |

Port P0 Input / Output Control Register

# Page: 100 / 278

# 汉芝电子股份有限公司 iMQ Technology Inc.

No. : TDDS01-M6812-EN

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| POCR<br>(0x0F1A) |    | 7           | 6 | 5 | 4 | 3 | 2 | 1                       | 0               |
|------------------|----|-------------|---|---|---|---|---|-------------------------|-----------------|
| Bit Symbo        | I  | Bit Symbol  | - | - | - | - | - | P0CR1                   | POCRO           |
| Read/Write       | 50 | Read/Write  | R | R | R | R | R | R/W                     | R/W             |
| After reset      | t  | After reset | 0 | 0 | 0 | 0 | 0 | 0                       | 0               |
| 0                |    |             |   |   |   |   |   | Input mode (port input) |                 |
| Function         | 1  |             |   |   |   |   |   | Output mode             | e (port output) |

### Port P0 Function Control Register

| P0FC<br>(0x0F34 |    | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
|-----------------|----|-------------|---|---|---|---|---|---|---------------|
| Bit Symbo       | ol | Bit Symbol  | - | - | - | - | - | - | P0FC0         |
| Read/Wri        | te | Read/Write  | R | R | R | R | R | R | R/W           |
| After rese      | et | After reset | 0 | 0 | 0 | 0 | 0 | 0 | 0             |
| Function        | 0  |             |   |   |   |   |   |   | Port function |
| Function        | 1  |             |   |   |   |   |   |   | XIN (I)       |

Note 1): When SYSCR2 <XEN> is "1", setting POFC0 to "0" generates a system clock (internal factor) reset. Normally, ports P00 or P01 are not used as ports, so P0FC0 must be set to "1".

Note 2]: Symbol "I" means secondary function input.

### Port PO Built-in Pull-up Resistor Control Resistor

| P0PU<br>(0x0F27 | 7)  | 7 | 6 | 5 | 4 | 3 | 2 | 1                               | 0                         |
|-----------------|-----|---|---|---|---|---|---|---------------------------------|---------------------------|
| BitSymbo        | ol  | - | - | - | - | - | - | P0PU1                           | POPUO                     |
| Read/Wri        | ite | R | R | R | R | R | R | R/W                             | R/W                       |
| Afterrese       | et  | 0 | 0 | 0 | 0 | 0 | 0 | 0                               | 0                         |
| Function        | 0   |   |   |   |   |   |   | The built-in re<br>connected.   | esistor is not            |
| Function        | 1   |   |   |   |   |   |   | The built-in p<br>is connected. | ull-up resistor<br>(Note) |

### Port PO Built-in Pull-down Resistor Control Resistor

|                 |     |   | WIT RESISCO |   |      |   |       |                                                                                                                                             |     |
|-----------------|-----|---|-------------|---|------|---|-------|---------------------------------------------------------------------------------------------------------------------------------------------|-----|
| P0PD<br>(0x0F00 | ))  | 7 | 6           | 5 | 4    | 3 | 2     | 1                                                                                                                                           | 0   |
| BitSymbo        | ol  | - | -           | - | POPD |   | P0PD1 | P0PD0                                                                                                                                       |     |
| Read/Wri        | ite | R | R           | R | R    | R | R     | R/W                                                                                                                                         | R/W |
| Afterrese       | et  | 0 | 0           | 0 | 0    | 0 | 0     | 0                                                                                                                                           | 0   |
|                 | 0   |   |             |   |      |   |       | The built-in resistor is connected.                                                                                                         |     |
| Function        | 1   |   |             |   |      |   |       | The resistor is connected<br>the input mode only. Un<br>any other conditions,<br>setting to "1" does not<br>make the resistor<br>connected. |     |

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Note): If POPUx and POPDx set to "1" at the same time, the port is only connected to pull-up resistor.[x=0,1]

| POPRD<br>(0x000D) | 7 | 6 | 5 | 4 | 3 | 2 | 1                                                                                              | 0      |
|-------------------|---|---|---|---|---|---|------------------------------------------------------------------------------------------------|--------|
| Bit Symbol        | - | - | - | - | - | - | POPRD1                                                                                         | POPRDO |
| Read/Write        | R | R | R | R | R | R | R                                                                                              | R      |
| After reset       | 0 | 0 | 0 | 0 | 0 | 0 | *                                                                                              | *      |
| Function          |   |   |   |   |   |   | If the port is in the inp<br>mode, the contents of<br>the port are read. If no<br>"0" is read. |        |

### Port P0 Input Data Register

# 8.3.2 Port P1(P10) Register

Port P1 is a 1-bit input / output por t (P10) that can be set to input or output for each bit individually.

Port P1 contains a programmable pull-up resistor on the VDD side. This pull-up can be used when the port is used in the input mode.

After reset, pin P10 serves as an I/O port. To use pin P10 as an external reset input, refer to "How to use the external reset input pin as a port" of "5.1 Reset Control Circuit".

| Port Name             | P10    |
|-----------------------|--------|
| Secondary<br>function | RESETB |

### Table 8.4 Port P1

### Port P1 Output Latch Register

| P1DR<br>(0x0001 | )  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                                 |  |  |  |
|-----------------|----|---|---|---|---|---|---|---|---------------------------------------------------|--|--|--|
| BitSymbol       |    | - | - | - | - | - | - | - | P10                                               |  |  |  |
| Read/Write      |    | R | R | R | R | R | R | R | R/W                                               |  |  |  |
| Afterrese       | et | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                                                 |  |  |  |
| 0               |    |   |   |   |   |   |   |   | Outputs L level when the output mode is selected. |  |  |  |
| Function        | 1  |   |   |   |   |   |   |   | Outputs H level when the output mode is selected. |  |  |  |

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## Port P1 Input / Output Control Register

| P1CR<br>(0x0F1B) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                         |
|------------------|---|---|---|---|---|---|---|---------------------------|
| BitSymbol        | - | - | - | - | - | - | - | P1CR0                     |
| Read/Write       | R | R | R | R | R | R | R | R/W                       |
| Afterreset       | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                         |
| 0                |   |   |   |   |   |   |   | Input mode (port input)   |
| Function 1       |   |   |   |   |   |   |   | Output mode (port output) |

### Port P1 Built-in Pull-up Resistor Control Resistor

| P1PU<br>(0x0F28 | 3) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                                                                                                                                 |
|-----------------|----|---|---|---|---|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------|
| BitSymbol       |    | - | - | - | - | - | - | - | P1PU0                                                                                                                                             |
| Read/Write      |    | R | R | R | R | R | R | R | R/W                                                                                                                                               |
| Afterreset      |    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                                                                                                                                                 |
|                 | 0  |   |   |   |   |   |   |   | The built-in resistor is not connected.                                                                                                           |
| Function        | 1  |   |   |   |   |   |   |   | The resistor is connected in<br>the input mode only.<br>Under any other<br>conditions, setting to "1"<br>does not make the resistor<br>connected. |

### Port P1 Input Data Register

| P1PRD<br>(0x000E) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                                                                                    |
|-------------------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------|
| BitSymbol         | - | - | - | - | - | - | - | P1PRD0                                                                                               |
| Read/Write        | R | R | R | R | R | R | R | R                                                                                                    |
| Afterreset        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | *                                                                                                    |
| Function          |   |   |   |   |   |   |   | If the port is in the input<br>mode, the contents of<br>the port are read. If not,<br>"0" is read. ° |

Note: "\*" means "don't care".

# 8.3.3 Port P2 (P27 to P20) Register

Port P2 is a 8-bit input / output port that can be set to input or output for each bit individually.

| Port Name             | P27   | P26   | P25 | P24         | P23 |
|-----------------------|-------|-------|-----|-------------|-----|
| Secondary<br>function | KWI11 | KWI10 | KW9 | KW18<br>SCL | sda |

Figure 8.4 Port P2

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

### Port P2 Output Latch Register

| P2DR<br>(0x0002 | 2)             | 7            | 6               | 5               | 4        | 3   | 2 | 1 | 0 |
|-----------------|----------------|--------------|-----------------|-----------------|----------|-----|---|---|---|
| Bit Symbo       | Ы              | P27          | P26             | P25             | P24      | P23 | - | - | - |
| Read/Wri        | Read/Write R/W |              | R/W             | R/W             | R/W      | R/W | R | R | R |
| After rese      | et             | t 0 0 0 0 0  |                 |                 |          | 0   | 0 | 0 | 0 |
| E               | 0              | Outputs L le | vel when the o  | utput mode is : |          |     |   |   |   |
| Function        | 1              | Outputs H le | evel when the c | output mode is  | selected |     |   |   |   |

### Port P2 Input / Output Control Register

| P2CR<br>(0x0F1C | ]  | 7 6 5 4 3    |                          |       |           |           | 2 | 1 | 0 |  |
|-----------------|----|--------------|--------------------------|-------|-----------|-----------|---|---|---|--|
| Bit Symbo       | ol | P2CR7        | P2CR6                    | P2CR5 | P2CR4     | P2CR3     | - | - | - |  |
| Read/Wri        | te | R/W          | R/W                      | R/W   | R/W       | R/W       | R | R | R |  |
| After rese      | et | 0            | 0                        | 0     | 0         | 0         | 0 | 0 | 0 |  |
|                 | 0: | Input mode ( | port input)              |       |           |           |   |   |   |  |
| Function        | 0. |              |                          |       |           |           |   |   |   |  |
| FUNCTION        | 1  | Output mode  | Itput mode (port output) |       |           |           |   |   |   |  |
|                 |    |              |                          |       | SCL (I/O) | SDA (I/O) |   |   |   |  |

Note: Symbol "I" means secondary function input. Symbol "O" means secondary function output. Symbol "I/O" means secondary

function input/output

### Port P2 Function Control Register

| P2FC<br>(0x0F36 |    | 7             | 6 | 5 | 4         | 3         | 2 | 1 | 0 |
|-----------------|----|---------------|---|---|-----------|-----------|---|---|---|
| Bit Symbo       | ol | -             | - | - | P2FC4     | P2FC3     | - | - | - |
| Read/Wri        | te | R             | R | R | R/W       | R/W       | R | R | R |
| After rese      | et | 0             | 0 | 0 | 0         | 0         | 0 | 0 | 0 |
| Function        | 0  | Port function |   |   |           |           |   |   |   |
| FUNCTION        | 1  |               |   |   | SCL (I/O) | SDA (I/O) |   |   |   |

### Port P2 Built-in Pull-up Resistor Control Resistor

| P2PU<br>(0x0F29 | <b>'</b> ) | 7               | 6                                                                                                                                   | 5        | 4     | 3     | 2 | 1 | 0 |  |
|-----------------|------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------|----------|-------|-------|---|---|---|--|
| Bit Symbo       | ol         | P2PU7           | P2PU6                                                                                                                               | P2PU5    | P2PU4 | P2PU3 | - | - | - |  |
| Read/Wri        | te         | R/W             | R/W                                                                                                                                 | R/W      | R/W   | R/W   | R | R | R |  |
| After rese      | et         | 0               | 0                                                                                                                                   | 0        | 0     | 0     | 0 | 0 | 0 |  |
|                 | 0          | The built-in re | esistor is not co                                                                                                                   | nnected. |       |       |   |   |   |  |
| Function        | 1          |                 | he resistor is connected in the input mode only. Under any other<br>onditions, setting to "1" does not make the resistor connected. |          |       |       |   |   |   |  |

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

### Port P2 Built-in Pull-down Resistor Control Resistor

| P2PD<br>(0x0F02 | 2) | 7               | 6                                                                                            | 5        | 4     | 3     | 2 | 1 | 0 |  |
|-----------------|----|-----------------|----------------------------------------------------------------------------------------------|----------|-------|-------|---|---|---|--|
| Bit Symbo       | Ы  | P2PD7           | P2PD6                                                                                        | P2PD5    | P2PD4 | P2PD3 | - | - | - |  |
| Read/Wri        | te | R/W             | R/W                                                                                          | R/W      | R/W   | R/W   | R | R | R |  |
| After rese      | et | 0               | 0                                                                                            | 0        | 0     | 0     | 0 | 0 | 0 |  |
|                 | 0  | The built-in re | esistor is not co                                                                            | nnected. |       |       |   |   |   |  |
| Function        | 1  |                 | ne resistor is connected in the input mode only. Under any other and the resistor connected. |          |       |       |   |   |   |  |

### Port P2 Input Data Register

| P2PRD<br>(0x000F) | 7                           | 6                | 5               | 4             | 3              | 2                | 1                  | 0           |
|-------------------|-----------------------------|------------------|-----------------|---------------|----------------|------------------|--------------------|-------------|
| Bit Symbol        | P2PRD7                      | P2PRD6           | P2PRD5          | P2PRD4        | P2PRD3         | -                | -                  | -           |
| Read/Write        | R                           | R                | R               | R             | R              | R                | R                  | R           |
| After reset       | *                           | *                | *               | *             | *              | 0                | 0                  | 0           |
| Function          | If the port is u<br>read. ° | used in the inpu | ut mode or as t | he open drain | output, the co | ntents of the po | ort are read. If r | not, "0" is |

### Port P2 Output Control Register

| P2OUTC<br>(0x0F43 |    | 7          | 6   | 5 | 4        | 3        | 2 | 1 | 0 |
|-------------------|----|------------|-----|---|----------|----------|---|---|---|
| Bit Symbo         | ol | -          | -   | - | P2OUTCR4 | P2OUTCR3 | - | - | - |
| Read/Writ         | e  | R          | R   | R | R/W      | R/W      | R | R | R |
| After rese        | t  | 0          | 0   | 0 | 0        | 0        | 0 | 0 | 0 |
| Europetia a       | 0  | Port funct | ion |   |          |          |   |   |   |
| Function          | 1  |            |     |   |          |          |   |   |   |

# 8.3.4 Port P4 (P47 to P40) Register

Port P4 is an 8-bit input/output port that can be set to input or output for each bit individually, and it is also used as the key-on wakeup input, LCD Driving, ADC input.

| Port Name             | P47          | P46          | P45          | P44          | P43          | P42          | P41          | P40          |
|-----------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Secondary<br>function | AIN7<br>KWI7 | AIN6<br>KWI6 | AIN5<br>KWI5 | AIN4<br>KWI4 | AIN3<br>KWI3 | AIN2<br>KWI2 | AIN1<br>KWI1 | AINO<br>KWIO |
| LCD                   | SEG8         | SEG9         | SEG10        | SEG11        |              |              |              |              |

### Table 8.5 Port P4

Note) : When use LCD function, set LCD related pin (COM and SEG) as input mode.

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

### Port P4 Output Latch Register

| P4DR<br>(0x0004 | 4)             | 7                                                 | 6                                                 | 5   | 4   | 3   | 2   | 1   | 0   |  |
|-----------------|----------------|---------------------------------------------------|---------------------------------------------------|-----|-----|-----|-----|-----|-----|--|
| BitSymbo        | bl             | P47                                               | P46                                               | P45 | P44 | P43 | P42 | P41 | P40 |  |
| Read/Wri        | Read/Write R/W |                                                   | R/W                                               | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Afterrese       | et             | 0 0 0 0 0 0 0                                     |                                                   |     |     |     |     |     |     |  |
| Function        | 0              | Outputs L leve                                    | Dutputs L level when the output mode is selected. |     |     |     |     |     |     |  |
| Function        | 1              | Outputs H level when the output mode is selected. |                                                   |     |     |     |     |     |     |  |

### Port P4 Input / Output Control Register

| P4CR<br>(0x0F1E | P4CR 7<br>(0x0F1E) |            | 6                         | 5        | 4        | 3                    | 2        | 1        | 0        |  |
|-----------------|--------------------|------------|---------------------------|----------|----------|----------------------|----------|----------|----------|--|
| BitSymbo        | Ы                  | P4CR7      | P4CR6                     | P4CR5    | P4CR4    | P4CR3                | P4CR2    | P4CR1    | P4CR0    |  |
| Read/Wri        | te                 | R/W        | R/W                       | R/W      | R/W      | R/W                  | R/W      | R/W      | R/W      |  |
| Afterrese       | et                 | 0          | 0                         | 0        | 0        | 0                    | 0        | 0        | 0        |  |
|                 |                    | Input mode | (port input)              |          |          |                      |          |          |          |  |
| Function        | 0                  | AIN7 (I)   | AIN6 (I)                  | AIN5 (I) | AIN4 (I) | AIN3 (I)<br>VREF (I) | AIN2 (I) | AIN1 (I) | AINO (I) |  |
|                 | 1                  | Output mo  | Dutput mode (port output) |          |          |                      |          |          |          |  |

Note]: Symbol "I" means secondary function input.

### Port P4 Function Control Register

| P4FC<br>(0x0F38 | 3) | 7             | 6        | 5        | 4        | 3                    | 2        | 1        | 0        |
|-----------------|----|---------------|----------|----------|----------|----------------------|----------|----------|----------|
| BitSymbo        | bl | P4FC7         | P4FC6    | P4FC5    | P4FC4    | P4FC3                | P4FC2    | P4FC1    | P4FC0    |
| Read/Wri        | te | R/W           | R/W      | R/W      | R/W      | R/W                  | R/W      | R/W      | R/W      |
| Afterrese       | et | 0             | 0        | 0        | 0        | 0                    | 0        | 0        | 0        |
|                 | 0  | Port function |          |          |          |                      |          |          |          |
| Function        | 1  | AIN7 (I)      | AIN6 (I) | AIN5 (I) | AIN4 (I) | AIN3 (I)<br>VREF (I) | AIN2 (I) | AIN1 (I) | AINO (I) |

### Port P4 Built-in Pull-up Resistor Control Register

| P4PU<br>(0x0F2B | 3) | 7               | 6                                                                                                                                                                                                                                | 5        | 4     | 3     | 2     | 1     | 0     |  |  |
|-----------------|----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------|-------|-------|-------|-------|--|--|
| BitSymbo        | bl | P4PU7           | P4PU6                                                                                                                                                                                                                            | P4PU5    | P4PU4 | P4PU3 | P4PU2 | P4PU1 | P4PU0 |  |  |
| Read/Wri        | te | R/W             | R/W                                                                                                                                                                                                                              | R/W      | R/W   | R/W   | R/W   | R/W   | R/W   |  |  |
| Afterrese       | et | 0               | 0                                                                                                                                                                                                                                | 0        | 0     | 0     | 0     | 0     | 0     |  |  |
|                 | 0  | The built-in re | esistor is not co                                                                                                                                                                                                                | nnected. |       |       |       |       |       |  |  |
| Function        | 1  |                 | The resistor is connected only when the key-on wakeup input (KW/ii) is enabled or the port is used in the input m<br>[P4FCi="0" and P4CRi="0"). Under any other conditions, setting to "1" does not make the resistor connected. |          |       |       |       |       |       |  |  |

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

### Port P4 Built-in Pull-down Resistor Control Register

| P4PD<br>(0x0F04 | +) | 7                          | 6                                                                                                                                 | 5        | 4     | 3     | 2     | 1     | 0     |  |  |
|-----------------|----|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------|-------|-------|-------|-------|-------|--|--|
| BitSymbo        | Ы  | P4PD7                      | P4PD6                                                                                                                             | P4PD5    | P4PD4 | P4PD3 | P4PD2 | P4PD1 | P4PD0 |  |  |
| Read/Wri        | te | R/W                        | R/W                                                                                                                               | R/W      | R/W   | R/W   | R/W   | R/W   | R/W   |  |  |
| Afterrese       | et | 0                          | 0                                                                                                                                 | 0        | 0     | 0     | 0     | 0     | 0     |  |  |
|                 | 0  | The built-in re            | esistor is not co                                                                                                                 | nnected. |       |       |       |       |       |  |  |
| Function        | 1  | The resistor is connected. | e resistor is connected in the input mode only. Under any other conditions, setting to "1" does not make the resistor<br>nnected. |          |       |       |       |       |       |  |  |

### Port P4 Input Data

| P4PRD<br>(0x0011) | 7                                                                                         | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|-------------------|-------------------------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|--------|
| Bit Symbol        | P4PRD7                                                                                    | P4PRD6 | P4PRD5 | P4PRD4 | P4PRD3 | P4PRD2 | P4PRD1 | P4PRD0 |
| Read/Write        | R                                                                                         | R      | R      | R      | R      | R      | R      | R      |
| After reset       | *                                                                                         | *      | *      | *      | *      | *      | *      | 0      |
| Function          | If the port is in the input mode, the contents of the port are read. If not, "0" is read. |        |        |        |        |        |        |        |

| Set Co | ndition | P4PRDi read value |  |  |  |
|--------|---------|-------------------|--|--|--|
| P4CRi  | P4FCi   | P4PRDI Tead Value |  |  |  |
| 0      | 0       | Contents of port  |  |  |  |
| *      | 1       | "0"               |  |  |  |
| 1 *    |         | "0"               |  |  |  |

### Table 8.7 P4PRD Read Value

Note 1): \* : Don't care Note 2): i= 0 to 7

## 8.3.5 Port P7 (P77 to P70) Register

Port P7 is a 8-bit input / output port that can be set to input or output for each bit individually, and it is also used as the external interrupt input, the divider output, LCD driving, SIO pins, and the timer counter input/output.

|                       | P77        | P76                   | P75                 | P74                         | P73   | P72            | P71    | P70    |
|-----------------------|------------|-----------------------|---------------------|-----------------------------|-------|----------------|--------|--------|
| Secondary<br>function | INT4<br>SS | INT3<br>KWI15<br>SCLK | INT2<br>KWI14<br>SO | KWI13<br>SI<br>DVOB<br>AIN8 | KWI12 | PPGA0B<br>TCA0 | PPG01B | PPG00B |
| LCD                   | SEG3       | SEG6                  | SEG4                | SEG7                        | СОМЗ  | COM2           |        | SEG5   |

### Table 8.7Port P7

Note) : When use LCD function, set LCD related pin (COM and SEG) as input mode.

### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

### Port P7 Output Latch Register

| P7DR<br>(0x0007 | ') | 7            | 6                                                 | 5   | 4   | 3   | 2   | 1   | 0   |  |
|-----------------|----|--------------|---------------------------------------------------|-----|-----|-----|-----|-----|-----|--|
| BitSymbol       |    | P77          | P76                                               | P75 | P74 | P73 | P72 | P71 | P70 |  |
| Read/Write      |    | R/W          | R/W                                               | R/W | R/W | R/W | R/W | R/W | R/W |  |
| Afterreset      |    | 0            | 0                                                 | 0   | 0   | 0   | 0   | 0   | 0   |  |
| Function -      | 0: | Outputs L le | Outputs L level when the output mode is selected. |     |     |     |     |     |     |  |
|                 | 1: | Outputs H    | Outputs H level when the output mode is selected. |     |     |     |     |     |     |  |

### Port P7 Input / Output Control Register

| P7CR<br>(0x0F21 | )  | 7                         | 6                    | 5        | 4                  | 3     | 2          | 1          | 0          |  |  |
|-----------------|----|---------------------------|----------------------|----------|--------------------|-------|------------|------------|------------|--|--|
| BitSymbol       |    | P7CR7                     | P7CR6                | P7CR5    | P7CR4              | P7CR2 | P7CR2      | P7CR1      | P7CR0      |  |  |
| Read/Write      |    | R/W                       | R/W                  | R/W      | R/W                | R/W   | R/W        | R/W        | R/W        |  |  |
| Afterrese       | et | 0                         | 0                    | 0        | 0                  | 0     | 0          | 0          | 0          |  |  |
|                 |    | Input mode (port input)   |                      |          |                    |       |            |            |            |  |  |
|                 | 0: | INT4 (I)<br>SS (I)        | INT3 (I)<br>SCLK (I) | INT2 (I) | AIN8 (I)<br>SI (I) |       | TAC0 (I)   |            |            |  |  |
|                 |    | Output mode (port output) |                      |          |                    |       |            |            |            |  |  |
|                 | 1: | SS (O)                    | SCLK (O)             | SO (O)   | DVOB (O)           |       | PPGA0B (O) | PMW01B (O) | PMW00B (O) |  |  |

Note): Symbol "I" means secondary function input. Symbol "O" means secondary function output.

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Port P7 Fund | ction Control Register | r |
|--------------|------------------------|---|
| DZEC         | _                      |   |

| P7FC<br>(0x0F3E | 3) | 7     | 6        | 5      | 4                              | 3 | 2          | 1          | 0          |
|-----------------|----|-------|----------|--------|--------------------------------|---|------------|------------|------------|
| BitSymbo        | ol | P7FC7 | P7FC6    | P7FC5  | P7FC4                          | - | P7FC2      | P7FC1      | P7FC0      |
| Read/Wri        | te | R/W   | R/W      | R/W    | R/W                            | R | R/W        | R/W        | R/W        |
| Afterrese       | et | 0     | 0        | 0      | 0                              | 0 | 0          | 0          | 0          |
|                 | 0: |       |          |        | Port functio                   | n |            |            |            |
| Function        | 1: | SS(O) | SCLK (O) | SO (O) | DVOB (O)<br>AIN8 (I)<br>SI (I) |   | PPGA0B (O) | PPG01B (O) | PPG00B (O) |

Note): When P7CR4 set to "0", it is AIN8. When P7CR4 set to "1", it is DVOB.

#### Port P7 Built-in Pull-up Resistor Control Resistor

| P7PU<br>(0x0F2E | )  | 7                          | 6                                       | 5             | 4                | 3               | 2                | 1              | 0                |  |  |
|-----------------|----|----------------------------|-----------------------------------------|---------------|------------------|-----------------|------------------|----------------|------------------|--|--|
| Bit Symbo       | ol | P7PU7                      | P7PU6                                   | P7PU5         | P7PU4            | P7PU3           | P7PU2            | P7PU1          | P7PU0            |  |  |
| Read/Wri        | te | R/W                        | R/W                                     | R/W           | R/W              | R/W             | R/W              | R/W            | R/W              |  |  |
| After rese      | et | 0                          | 0                                       | 0             | 0                | 0               | 0                | 0              | 0                |  |  |
|                 | 0  | The built-in re            | The built-in resistor is not connected. |               |                  |                 |                  |                |                  |  |  |
| Function        | 1  | The resistor is connected. | connected in t                          | he input mode | e only. Under ar | ny other condit | ions, setting to | "1" does not m | ake the resistor |  |  |

#### Port P7 Built-in Pull-down Resistor Control Resistor

| P7PD<br>(0x0F07 | <b>'</b> ) | 7                          | 6                                       | 5              | 4                | 3               | 2                | 1              | 0                |  |  |
|-----------------|------------|----------------------------|-----------------------------------------|----------------|------------------|-----------------|------------------|----------------|------------------|--|--|
| Bit Symbo       | ol         | P7PD7                      | P7PD6                                   | P7PD5          | P7PD4            | P7PD3           | P7PD2            | P7PD1          | P7PD0            |  |  |
| Read/Wri        | te         | R/W                        | R                                       | R/W            | R/W              | R/W             | R/W              | R/W            | R/W              |  |  |
| After rese      | et         | 0                          | 0                                       | 0              | 0                | 0               | 0                | 0              | 0                |  |  |
|                 | 0          | The built-in re            | The built-in resistor is not connected. |                |                  |                 |                  |                |                  |  |  |
| Function        | 1          | The resistor is connected. | connected in t                          | the input mode | e only. Under ar | ny other condit | ions, setting to | "1" does not m | ake the resistor |  |  |

Note: If set P7PUx to "1" and P7PDx to "1" at the same time, port is only connect to pull-up resistor (x=7 to 0

#### Port P7 Input Data

| P7PRD<br>(0x0014)                                                                                  | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|----------------------------------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Bit Symbol                                                                                         | P7PRD7 | P7PRD6 | P7PRD5 | P7PRD4 | P7PRD3 | P7PRD2 | P7PRD1 | P7PRD0 |
| Read/Write                                                                                         | R      | R      | R      | R      | R      | R      | R      | R      |
| After reset                                                                                        | *      | *      | *      | *      | *      | *      | *      | *      |
| Function If the port is in the input mode, the contents of the port are read. If not, "0" is read. |        |        |        |        |        |        |        |        |

# 8.3.6 Port P8 (P83 to P80) Register

Port P8 is a 4-bit input/output port that can be set to input or output for each bit individually, and it is also used as the timer counter input/output, and LCD driving. P80 and P81 are input port only.

| Port Name             | P83    | P82    | P81    | P80    |
|-----------------------|--------|--------|--------|--------|
| Secondary<br>function | PPG05B | PPG04B | PPG03B | PPG02B |
| LCD                   | COM5   | COM4   | -      | -      |

#### Table 8.8 Port P8

Note) : When use LCD function, set LCD related pin (COM and SEG) as input mode

#### Port P8 Output Latch Register

| P8DR<br>(0x0008 | 3) | 7 | 6 | 5 | 4 | 3                                                | 2              | 1             | 0        |  |
|-----------------|----|---|---|---|---|--------------------------------------------------|----------------|---------------|----------|--|
| Bit Symbo       | ol | - | - | - | - | P83                                              | P82            | P81           | P80      |  |
| Read/Wri        | te | R | R | R | R | R/W                                              | R/W            | R/W           | R/W      |  |
| After rese      | et | 0 | 0 | 0 | 0 | 0                                                | 0              | 0             | 0        |  |
| Function        | 0: |   |   |   |   | Outputs L level when the output mode is selected |                |               |          |  |
| Function        | 1: |   |   |   |   | Outputs H lev                                    | vel when the o | utput mode is | selected |  |

#### Port P8 Input / Output Control Register

| P8CR<br>(0x0F22 | 2) | 7 | 6 | 5 | 4 | 3                                            | 2               | 1          | 0          |
|-----------------|----|---|---|---|---|----------------------------------------------|-----------------|------------|------------|
| Bit Symbo       | ol | - | - | - | - | P8CR3                                        | P8CR2           | P8CR1      | P8CR0      |
| Read/Wri        | te | R | R | R | R | R/W                                          | R/W             | R/W        | R/W        |
| After rese      | et | 0 | 0 | 0 | 0 | 0                                            | 0               | 0          | 0          |
|                 | 0: |   |   |   |   | Input mode (port input) Do not use Input mod |                 |            |            |
| Function        |    |   |   |   |   | Output mode                                  | e (port output) |            |            |
| FUNCTION        | 1: |   |   |   |   | PPG05B (O)                                   | PPG04B (O)      | PPG03B (O) | PPG02B (O) |

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

#### Port P8 Function Control Register

| P8FC<br>(0x0F30 | <b>_</b> ) | 7 | 6 | 5 | 4 | 3             | 2             | 1           | 0          |
|-----------------|------------|---|---|---|---|---------------|---------------|-------------|------------|
| Bit Symbo       | ol         | - | - | - | - | P8FC3         | P8FC2         | P8FC1       | P8FC0      |
| Read/Wri        | te         | R | R | R | R | R/W           | R/W           | R/W         | R/W        |
| After rese      | et         | 0 | 0 | 0 | 0 | 0             | 0             | 0           | 0          |
|                 | 0:         |   |   |   |   | Port functior | n (P80/P81 is | input only) |            |
| Function        | 1:         |   |   |   |   | PPG05B (O)    | PPG04B (O)    | PPG03B (O)  | PPG02B (O) |

#### Port P8 Built-in Pull-up Resistor Control Resistor

| P8PU<br>(0x0F2F | =)  | 7 | 6 | 5 | 4 | 3                             | 2                                                                             | 1 | 0 |
|-----------------|-----|---|---|---|---|-------------------------------|-------------------------------------------------------------------------------|---|---|
| Bit Symb        | ol  | - | - | - | - | P8PU3                         | P8PU2                                                                         | - | - |
| Read/Wr         | ite | R | R | R | R | R/W                           | R/W                                                                           | R | R |
| After res       | et  | 0 | 0 | 0 | 0 | 0                             | 0                                                                             | 0 | 0 |
|                 | 0   |   |   |   |   | The built-in re<br>connected. | esistor is not                                                                |   |   |
| Function        | 1   |   |   |   |   | the input mo<br>any other     | s connected in<br>de only. Under<br>conditions,<br>does not make<br>onnected. |   |   |

#### Port P8 Built-in Pull-down Resistor Control Resistor

| P8PD<br>(0x0F08 | 3) | 7 | 6 | 5 | 4 | 3                             | 2                                                                             | 1 | 0 |
|-----------------|----|---|---|---|---|-------------------------------|-------------------------------------------------------------------------------|---|---|
| Bit Symbol      |    | - | - | - | - | P8PD3                         | P8PD2                                                                         | - | - |
| Read/Wri        | te | R | R | R | R | R/W                           | R/W                                                                           | R | R |
| After rese      | et | 0 | 0 | 0 | 0 | 0                             | 0 0                                                                           |   | 0 |
|                 | 0  |   |   |   |   | The built-in re<br>connected. | esistor is not                                                                |   |   |
| Function 1      |    |   |   |   |   | the input mo<br>any other     | s connected in<br>de only. Under<br>conditions,<br>does not make<br>onnected. |   |   |

Note: If set P8PUx to "1" and P78Dx to "1" at the same time, port is only connect to pull-up resistor (x=0,1)

#### Port P8 Input Data Register

| P8PRD<br>(0x0015) | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|-------------------|---|---|---|---|--------|--------|--------|--------|
| Bit Symbol        | - | - | - | - | P8PRD3 | P8PRD2 | P8PRD1 | P8PRD0 |
| Read/Write        | R | R | R | R | R      | R      | R      | R      |
| After reset       | 0 | 0 | 0 | 0 | *      | *      | *      | *      |

# 汉芝电子股份有限公司 iMQ Technology Inc.

| No. : TDD | S01-M6812-I | EN | Name : N | Name : MQ6812/MQ6821/MQ6822 Datasheet |  |                                                   |  |  | Version : V1.1 |  |
|-----------|-------------|----|----------|---------------------------------------|--|---------------------------------------------------|--|--|----------------|--|
| ſ         |             |    |          |                                       |  |                                                   |  |  | 1              |  |
|           | Function    |    |          |                                       |  | If the port is in the input mode, the contents of |  |  |                |  |
|           | Function    |    |          |                                       |  | the port are read. If not                         |  |  |                |  |

Note : "\*" means "don't care".

# 8.3.7 Port P9 (P91 to P90)

Port P9 is a 2-bit input/output port that can be set to input or output for each bit individually, and it is also used as the UART.

"0" is read.

| Port Name             | P91          | P90          |
|-----------------------|--------------|--------------|
| Secondary<br>function | RXD1<br>TXD1 | TXD1<br>RXD1 |
| LCD                   | COM1         | COM0         |

## Table 8.10 Port P9

Note) : When use LCD function, set LCD related pin (COM and SEG) as input mode

#### Port P9 Output Latch Register

| P9DR<br>(0x0009 | 2) | 7 | 6 | 5 | 4 | 3 | 2 | 1                            | 0   |
|-----------------|----|---|---|---|---|---|---|------------------------------|-----|
| Bit Symbol      |    | - | - | - | - | - | - | P91                          | P90 |
| Read/Wri        | te | R | R | R | R | R | R | R/W                          | R/W |
| After rese      | et | 0 | 0 | 0 | 0 | 0 | 0 | 0                            | 0   |
| 0:              |    |   |   |   |   |   |   | Outputs L lev<br>output mode |     |
| Function        | 1: |   |   |   |   |   |   | Outputs H le<br>output mode  |     |

#### Port P9 Input / Output Control Register

| P9CR<br>(0x0F23 | 3) | 7 | 6 | 5 | 4 | 3 | 2 | 1                       | 0               |
|-----------------|----|---|---|---|---|---|---|-------------------------|-----------------|
| Bit Symbol      |    | - | - | - | - | - | - | P9CR1                   | P9CR0           |
| Read/Write      |    | R | R | R | R | R | R | R/W                     | R/W             |
| After reset     |    | 0 | 0 | 0 | 0 | 0 | 0 | 0                       | 0               |
|                 | 0. |   |   |   |   |   |   | Input mode (port input) |                 |
|                 | 0: |   |   |   |   |   |   | RXD1 (I)                | RXD1 (I)        |
| Function        |    |   |   |   |   |   |   | Output mode             | e (port output) |
|                 | 1: |   |   |   |   |   |   | TXD1(O)                 | TXD1(O)         |

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| UART Ir          | npu | t/Output C | hange Cor | ntrol Regist | ter |   |                                                                                                         |                                |   |
|------------------|-----|------------|-----------|--------------|-----|---|---------------------------------------------------------------------------------------------------------|--------------------------------|---|
| UATCN<br>(0x0E57 |     | 7          | 6         | 5            | 4   | 3 | 2                                                                                                       | 1                              | 0 |
| Bit Symbol       |     | -          | -         | -            | -   | - | UAT2IO                                                                                                  | UAT1IO                         | - |
| Read/Wri         | te  | R          | R         | R            | R   | R | R/W                                                                                                     | R/W                            | R |
| After rese       | et  | 0          | 0         | 0            | 0   | 0 | 0                                                                                                       | 0                              | 0 |
|                  | 0:  |            |           |              |     |   | Set P90 and<br>P91 as UART<br>function.                                                                 | Set P90 is TXD;<br>P91 is RXD. |   |
| Function         | 1:  |            |           |              |     |   | Set P26 and<br>P27 as UART<br>function.(P26.<br>P27 can not<br>use TCC<br>function at the<br>same time) | Set P90 is RXD;<br>P91 is TXD. |   |

Note): Bit2(UAT2IO) use to choose P90/P91 or P26/P27 as UART pin. If Bit2=0, P90/P91 is UART, and set P90/P91 as TXD1/RXD1 by Bit1 (UAT1IO). If Bit2=1, P26/P27 is UART(P26/P27 cannot use TCC function at this time), and set P26/P27 as TXD1/RXD1 by Bit1 (UAT1IO). The operation for changing UATCNG must be executed while the applicable serial interface operations are stopped.

#### Port P9 Function Control Register

| P9FC<br>(0x0F3D | <b>)</b> ) | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|-----------------|------------|---|---|---|---|---|---|---------|---------|
| Bit Symbol      |            | - | - | - | - | - | - | P9FC1   | P9FC0   |
| Read/Write      |            | R | R | R | R | R | R | R/W     | R/W     |
| After rese      | et         | 0 | 0 | 0 | 0 | 0 | 0 | 0       | 0       |
|                 | 0:         |   |   |   |   |   |   | Port fu | inction |
| Function        | 1:         |   |   |   |   |   |   | TXD1(O) | TXD1(O) |

#### Port P9 Built-in Pull-up Resistor Control Resistor

| P9PU<br>(0x0F30 | )) | 7 | 6 | 5 | 4 | 3 | 2 | 1                                                                                                                                | 0              |
|-----------------|----|---|---|---|---|---|---|----------------------------------------------------------------------------------------------------------------------------------|----------------|
| Bit Symbol      |    | - | - | - | - | - | - | P9PU1                                                                                                                            | P9PU0          |
| Read/Write      |    | R | R | R | R | R | R | R/W                                                                                                                              | R/W            |
| After reset     |    | 0 | 0 | 0 | 0 | 0 | 0 | 0                                                                                                                                | 0              |
|                 | 0  |   |   |   |   |   |   | The built-in re<br>connected.                                                                                                    | esistor is not |
| Function        | 1  |   |   |   |   |   |   | The resistor is connecte<br>the input mode only. Ur<br>any other conditi<br>setting to "1" does not m<br>the resistor connected. |                |

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

#### Port P9 Built-in Pull-down Resistor Control Resistor

| P9PD<br>(0x0F09 | 2) | 7 | 6 | 5 | 4 | 3 | 2 | 1                                                                                                                                 | 0              |
|-----------------|----|---|---|---|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------|----------------|
| Bit Symb        | ol | - | - | - | - | - | - | P9PD1                                                                                                                             | P9PD0          |
| Read/Write      |    | R | R | R | R | R | R | R/W                                                                                                                               | R/W            |
| After reset     |    | 0 | 0 | 0 | 0 | 0 | 0 | 0                                                                                                                                 | 0              |
|                 | 0  |   |   |   |   |   |   | The built-in reconnected.                                                                                                         | esistor is not |
| Function        | 1  |   |   |   |   |   |   | The resistor is connected<br>the input mode only. Ur<br>any other conditi<br>setting to "1" does not m<br>the resistor connected. |                |

Note: If set P9PUx to "1" and P79Dx to "1" at the same time, port is only connect to pull-up resistor (x=0,1)

#### Port P9 Input Data Register

| P9PRD<br>(0x0016) | 7 | 6 | 5 | 4 | 3 | 2 | 1                                                                           | 0                      |
|-------------------|---|---|---|---|---|---|-----------------------------------------------------------------------------|------------------------|
| Bit Symbol        | - | - | - | - | - | - | P9PRD1                                                                      | P9PRD0                 |
| Read/Write        | R | R | R | R | R | R | R                                                                           | R                      |
| After reset       | 0 | 0 | 0 | 0 | 0 | 0 | *                                                                           | *                      |
| Function          |   |   |   |   |   |   | If the port is<br>input modet<br>contents of f<br>read.<br>If not, "0" is r | t, the<br>the port are |

Note : "\*" means "don't care".

# 9.10-bit AD Converter (ADC)

MQ6812/MQ6821 has a real 10-bit AD converter (ADC), which is a successive approximation type ADC. There are maximum 9 input pins(AIN0 to AIN8), and 1 internal 1/4 VDD battery measure input pin.

# 9.1 Configuration

The circuit configuration of the 10-bit AD converter is shown in Figure 9.1.

It consists of control registers ADCCR1 and ADCCR2, converted value registers ADCDRL and ADCDRH, a DA converter, a sample-hold circuit, a comparator, a successive comparison circuit, etc.





Note 1): Before using the AD converter, set an appropriate value to the I/O port register which is also used as an analog input port. For details, see the section on "8 I/O ports".

# 9.2 Control

The AD converter consists of the following four registers:

1. AD converter control register 1 (ADCCR1)

This register selects an analog channel in which to perform AD conversion, selects an AD conversion operation mode, and controls the start of the AD converter.

2. AD converter control register 2 (ADCCR2)

This register selects the AD conversion time, and monitors the operating status of the AD

# Page: 115/ 278

converter.

3. AD converter reference voltage register (ADCVRF)

The register selects the reference voltage source of the AD converter.

4. AD converted value registers (ADCDRH and ADCDRL)

These registers store the digital values generated by the AD converter.

#### AD Converter Control Register 1

| ADCCR1<br>(0x0034H) | 7    | 6   | 5   | 4     | 3    | 2   | 1   | 0   |
|---------------------|------|-----|-----|-------|------|-----|-----|-----|
| Bit Symbol          | ADRS | AMD |     | AINEN | SAIN |     |     |     |
| Read/Write          | R/W  | R/W | R/W | R/W   | R/W  | R/W | R/W | R/W |
| After reset         | 0    | 0   | 0   | 0     | 0    | 0   | 0   | 0   |

| ADRS  | AD conversion start         | 0:<br>1:                                                                                                     | -<br>AD conversion start                                                                                                     |
|-------|-----------------------------|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| AMD   | AD operating mode           | 00:<br>01:<br>10:<br>11:                                                                                     | AD operation disable, forcibly stop AD operation<br>Single mode<br>Reserved<br>Repeat mode                                   |
| AINEN | Analog input control        | 0:<br>1:                                                                                                     | Analog input disable<br>Analog input enable                                                                                  |
| SAIN  | Analog input channel select | 0000<br>0001:<br>0010:<br>0100:<br>0101:<br>0100:<br>0111:<br>1000<br>1001<br>1010<br>1011<br>1100<br>Others | AIN0<br>AIN1<br>AIN2<br>AIN3<br>AIN4<br>AIN5<br>AIN6<br>AIN7<br>AIN8<br>1/4 VDD input<br>Reserved<br>Reserved<br>ground<br>- |

Note 1/: Do not perform the following operations on the ADCCR1 register while AD conversion is being executed (ADCCR2 <ADBF>="1"].

- Changing SAIN
- Setting AINEN to "0"

- Changing AMD (except a forced stop by setting AMD to "00")

- Setting ADRS to "1"

Note 2]: If you want to disable all analog input channels, set AINEN to "0".

Note 3]: Although analog input pins are also used as input/output ports, it is recommended for the purpose of maintaining the accuracy of AD conversion that you do not execute input/output instructions during AD conversion. Additionally, do not input widely varying signals into the ports adjacent to analog input pins.

Note 4/: When STOP, IDLE0 or SLOW mode is started, ADRS, AMD and AINEN are initialized to "0". If you use the AD converter after returning to NORMAL mode, you must reconfigure ADRS, AMD and AINEN.

Note 5): After the start of AD conversion, ADRS is automatically cleared to "0" ("0" is read).

Note 6):When P74 is AIN8, and other AIN is operate in at the same time, it would increase extra power consumption. Avoid using P74 as AIN8, if there are still enough AIN pin.

AD Converter Control Register 2

Name : MQ6812/MQ6821/MQ6822 Datasheet

| ADCCR2<br>(0x0035H) | 7    | 6    | 5 | 4 | 3  | 2   | 1   | 0   |  |
|---------------------|------|------|---|---|----|-----|-----|-----|--|
| Bit Symbol          | EOCF | ADBF | - | - | -  |     | АСК |     |  |
| Read/Write          | R    | R    | R | R | W/ | R/W | R/W | R/W |  |
| After reset         | 0    | 0    | 0 | 0 | 0  | 0   | 0   | 0   |  |

| EOCF | AD conversion end flag       | 0:<br>1: | Before conversion or during conversion<br>Conversion end   |
|------|------------------------------|----------|------------------------------------------------------------|
| ADBF | ADBF AD conversion BUSY flag |          | AD conversion being halted<br>AD conversion being executed |
| ACK  | AD conversion time select    |          | Refer to Table 9.1 for AD conversion time                  |

Note 1): Make sure that you make the ACK setting when AD conversion is in a halt condition (ADCCR2 <ADBF>="0"]. Note 2]: Make sure that you write "0" to bit 3 of ADCCR2.

Note 3): If STOP, IDLE0 or SLOW mode is started, EOCF and ADBF are initialized to "0".

Note 4]: If the AD converted value register (ADCDRH) is read, EOCF is cleared to "0". It is also cleared to "0" if AD conversion is started (ADCCR1 <ADRS>="1") without reading ADCDRH after completing AD conversion in single mode.

Note 5]: If an instruction to read ADCCR2 is executed, 0 is read from bits 3 through 5.

|                |                    | Frequency (fcgck) |          |          |          |          |          |          |  |
|----------------|--------------------|-------------------|----------|----------|----------|----------|----------|----------|--|
| ACK<br>setting | Conversion<br>time | 16MHz             | 8MHz     | 4MHz     | 2MHz     | 1MHz     | 0.5MHz   | 0.25MHz  |  |
| 000            | 32/fcgck           | -                 | -        | -        | 16.0 us  | 32.0 us  | 64.0 us  | 128.0 us |  |
| 001            | 64/fcgck           | -                 | -        | 16.0 us  | 32.0 us  | 64.0 us  | 128.0 us | -        |  |
| 010            | 128/fcgck          | -                 | 16.0 us  | 32.0 us  | 64.0 us  | 128.0 us | -        | -        |  |
| 011            | 256/fcgck          | 16.0 us           | 32.0 us  | 64.0 us  | 128.0 us | -        | -        | -        |  |
| 100            | 512/fcgck          | 32.0 us           | 64.0 us  | 128.0 us | -        | -        | -        | -        |  |
| 101            | 1024/fcgck         | 64.0 us           | 128.0 us | -        | -        | -        | -        | -        |  |

#### Table 9.1 ACK Settings and Conversion Times Relative to Frequencies

Note 1): Spaces indicated by "-" in the above table mean that it is prohibited to establish conversion times in these spaces. fcgck: High Frequency oscillation clock [Hz]

Note 2]: The conversion time must be longer than the following time by analog reference voltage (VAREF)

- VAREF = 2.7 to 5.5V 12.8μs or longer.
- VAREF = 2.0 to 2.7V 25.6µs or longer.

Note 3]: When using other fcgck, please set ACK to calculate conversion time, please keep conversion time equal or more than 16us.

Note 4]: Above conversion times do not include the time shown below.

- Time from when ADCCR1<ADRS> is set to 1 to when AD conversion is started
- Time from when AD conversion is finished to when a converted value is stored in ADCDRL and ADCDRH. Please refer to below table for longest wakeup time vs. ACK setting

# 汉芝电子股份有限公司 iMQ Technology Inc.

# No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| ACK Setting                                                |                         |  |  |  |  |  |  |  |
|------------------------------------------------------------|-------------------------|--|--|--|--|--|--|--|
| 000                                                        | 000 001 010 011 100 101 |  |  |  |  |  |  |  |
| 32/fcgck 64/fcgck 128/fcgck 256/fcgck 512/fcgck 1024/fcgck |                         |  |  |  |  |  |  |  |

#### Table 9.2 ADC Wakeup Time vs. ACK Setting

#### AD Converter Reference Voltage Register

| ADCVRF<br>(0x0EE7) | 7 | 6 | 5 | 4 | 3 | 2      | 1   | 0   |
|--------------------|---|---|---|---|---|--------|-----|-----|
| Bit Symbol         | - | - | - | - | - | VRFSEL |     |     |
| Read/Write         | R | R | R | R | R | R/W    | R/W | R/W |
| After reset        | 0 | 0 | 0 | 0 | 0 | 0      | 0   | 0   |

|        |                     | 000: | ADC internal reference voltage = 2.0V                    |
|--------|---------------------|------|----------------------------------------------------------|
|        | Choose AD Converter | 001: | ADC internal reference voltage = 3.0V                    |
|        |                     | 001. | ADC Internal reference voltage = 5.0V                    |
|        |                     | 010: | ADC internal reference voltage = 4.0V                    |
| VRFSEL |                     | 011: | ADC internal reference voltage = VDD                     |
| VIGSEE | Reference Voltage   | 100: | ADC reference voltage = external reference voltage(VREF) |
|        |                     | 101: | Syetem reserved.                                         |
|        |                     | 110: | Syetem reserved.                                         |
|        |                     | 111: | Syetem reserved.                                         |

#### AD internal reference voltage auto caliberation register

| VREF_CALIB<br>(0x0EF6) | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 |
|------------------------|---|---|---|---|---|---|--------|---|
| Bit Symbol             | - | - | - | - | - | - | VRFCAL | - |
| Read/Write             | R | R | R | R | R | R | R/W    | R |
| After reset            | 0 | 0 | 0 | 0 | 0 | 0 | 0      | 0 |

| VRFCAL | ADC internal voltage autocaliberation function | 0: auto calibration disable<br>1: auto calibration enable |
|--------|------------------------------------------------|-----------------------------------------------------------|
|--------|------------------------------------------------|-----------------------------------------------------------|

Note : Detail of auto-calibration function, please refer to appendix D.

#### AD Converted Value Register (Lower Side)

| ADCDRL<br>(0x0036) | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|--------------------|------|------|------|------|------|------|------|------|
| Bit Symbol         | AD07 | AD06 | AD05 | AD04 | AD03 | AD02 | AD01 | AD00 |
| Read/Write         | R    | R    | R    | R    | R    | R    | R    | R    |
| After reset        | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

#### AD Converted Value Register (Upper Side)

| ADCDRH<br>(0x0037) | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|--------------------|---|---|---|---|---|---|------|------|
| Bit Symbol         | - | - | - | - | - | - | AD09 | AD08 |
| Read/Write         | R | R | R | R | R | R | R    | R    |
| After reset        | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    |

Note 1): A read of ADCDRL or ADCDRH must be read after the INTADC interrupt is generated or after ADCCR2 <EOCF> becomes "1".

Note 2]: In single mode, do not read ADCDRL or ADCDRH during AD conversion (ADCCR2 <ADBF>="1"). (If AD conversion is finished in the interim between a read of ADCDRL and a read of ADCDRH, the INTADC interrupt request is canceled, and the conversion result is lost.)

Note 3): If STOP, IDLE0 or SLOW mode is started, ADCDRL and ADCDRH are initialized to "0".

Note 4): If ADCCR1<AMD> is set to "00", ADCDRL and ADCDRH are initialized to "0".

Note 5): If an instruction to read ADCDRH is executed, "0" is read from bits 7 through 2.

Note 6): If AD conversion is finished in repeat mode in the interim between a read of ADCDRL and a read of ADCDRH, the previous converted value is retained without overwriting the AD converted value register. In this case, the INTADC interrupt request is canceled, and the conversion result is lost.

# 9.3 Function

The 10-bit AD converter operates in either single mode in which AD conversion is performed only once or repeat mode in which AD conversion is performed repeatedly.

## 9.3.1 Single Mode

In single mode, the voltage at a designated analog input pin is AD converted only once.

Setting ADCCR1 <ADRS> to "1" after setting ADCCR1 <AMD> to "01" allows AD conversion to start. ADCCR1 <ADRS> is automatically cleared after the start of AD conversion. As AD conversion starts, ADCCR2 <ADBF> is set to "1". It is cleared to "0" if AD conversion is finished or if AD conversion is forced to stop.

After AD conversion is finished, the conversion result is stored in the AD converted value registers (ADCDRL and ADCDRH), ADCCR2 <EOCF> is set to "1", and the AD conversion finished interrupt (INTADC) is generated. The AD converted value registers (ADCDRL and ADCDRH) should be usually read according to the INTADC interrupt processing routine. If the upper side (ADCDRH) of the AD converted value register is read, ADCCR2 <EOCF> is cleared to "0".

## Page: 119/ 278

# 汉芝电子股份有限公司

iMQ Technology Inc. No. : TDDs01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1



#### Figure 9.2 Single Mode

Note): Do not perform the following operations on the ADCCR1 register when AD conversion is being executed (ADCCR2 <ADBF>="1"]. If the following operations are performed, there is the possibility that AD conversion may not be executed properly.

- Changing the ADCCR1<SAIN> setting
- Setting ADCCR1<AINEN> to "0"
- Changing the ADCCR1<AMD> setting (except a forced stop by setting AMD to "00")
- Setting ADCCR1<ADRS> to "1"

# 9.3.2 Repeat Mode

In repeat mode, the voltage at an analog input pin designated at ADCCR1<SAIN> is AD converted repeatedly. Setting ADCCR1 <ADRS> to "1" after setting ADCCR1 <AMD> to "11" allows AD conversion to start.

After the start of AD conversion, ADCCR1 <ADRS> is automatically cleared. After the first AD conversion is finished, the conversion result is stored in the AD converted value registers (ADCDRL and ADCDRH), ADCCR2 <EOCF> is set to "1", and the AD conversion finished interrupt (INTADC) is generated. After this interrupt is generated, the second (next) AD conversion starts immediately.

The AD converted value registers (ADCDRL and ADDRH) should be read before the next AD conversion is finished. If the next AD conversion is finished in the interim between a read of ADCDRL and a read of ADCDRH, the previous converted value is retained without overwriting the AD converted value registers (ADCDRL and ADCDRH). In this case, the INTADC interrupt request is not generated, and the conversion result is lost. (See Figure 9.3)

To stop AD conversion, write "00" (AD operation disable) to ADCCR1 <AMD>. As "00" is written to ADCCR1 <AMD>, AD conversion stops immediately. In this case, the converted value is not stored in the AD converted value register. As AD conversion starts, ADCCR2 <ADBF> is set to "1". It is cleared

# Page: 120/ 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

to "0" if "00" is written to AMD.



Figure 9.3 Repeat Mode

# 9.3.3 AD Operation Disable and Forced Stop of AD Operation

If you want to force the AD converter to stop when AD conversion is ongoing in single mode or if you want to stop the AD converter when AD conversion is ongoing in repeat mode, set ADCCR1 <AMD> to "00".

If ADCCR1 <AMD> is set to "00", registers ADCCR2 <EOCF>, ADCCR2 <ADBF>, ADCDRL, and ADCDRH are initialized to "0".

# 9.4 Register Setting

- 1. Set the AD converter control register 1 (ADCCR1) as described below:
  - 1. From the AD input channel select (SAIN), select the channel in which AD conversion is to be performed.
  - 2. Set the analog input control (AINEN) to "Analog input enable".
  - 3. At AMD, specify the AD operating mode (single or repeat mode).
- 2. Set the AD converter control register 2 (ADCCR2) as described below:

At the AD conversion time (ACK), specify the AD conversion time. For information on how to specify the conversion time, refer to the AD converter control register 2 and Table 9.1.

# Page: 121/ 278

| 汉芝电子股份有限公司            |                                      |                |
|-----------------------|--------------------------------------|----------------|
| iMQ Technology Inc.   |                                      |                |
| No. : TDDS01-M6812-EN | Name: MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

- 3. After the above two steps are completed, set "1" on the AD conversion start (ADRS) of the AD converter control register 1 (ADCCR1), and AD conversion starts immediately if single mode is selected.
- As AD conversion is finished, the AD conversion end flag (EOCF) of the AD converter control register
   2 (ADCCR2) is set to "1", the AD conversion result is stored in the AD converted value registers
   (ADCDRH and ADCDRL), and the INTADC interrupt request is generated.
- 5. After the conversion result is read from the AD converted value register (ADCDRH), EOCF is cleared to "0". EOCF will also be cleared to "0" if AD conversion is performed once again before reading the AD converted value register (ADCDRH). In this case, the previous conversion result is retained until AD conversion is finished.

# 9.5 Starting STOP/IDLE0/SLOW Modes

If STOP/IDLE0/SLOW mode is started, registers ADCCR1 <ADRS, AMD, AINEN>, ADCCR2 <EOCF, ADBF>, ADCDRL and ADCDRH are initialized to "0". If any of these modes is started during AD conversion, AD conversion is suspended, and the AD converter stops (registers are likewise initialized). When restored from STOP/IDLE0/SLOW mode, AD conversion is not automatically restarted. Therefore, registers must be reconfigured as necessary.

If STOP/IDLE0/SLOW mode is started during AD conversion, analog reference voltage is automatically disconnected and, therefore, there is no possibility of current flowing into the analog reference voltage.

# 9.6 Analog Input Voltage and AD Conversion Result

Analog input voltages correspond to AD-converted, 10-bit digital values, as shown in Figure 9.4.



Figure 9.4 Relationships between Analog Input Voltages and AD-converted Values (Typical Values)

# Page: 122 / 278

# 9.7 Precautions about the AD Converter9.7.1 Analog Input Pin Voltage Range

Analog input pins (AIN0 through AIN8) should be used at voltages from VAREF to VSS. If any voltage outside this range is applied to one of the analog input pins, the converted value on that pin becomes uncertain, and converted values on other pins will also be affected.

# 9.7.2 Analog Input Pins Used as Input / Output Ports

Analog input pins (AIN0 through AIN8) are also used as input/output ports. In using one of analog input pins (ports) to execute AD conversion, input/output instructions at all other pins (ports) must not be executed. If they are executed, there is the possibility that the accuracy of AD conversion may deteriorate. This also applies to pins other than analog input pins; if one pin receives inputs or generates outputs, noise may occur and its adjacent pins may be affected by that noise.

# 9.7.3 Noise Countermeasure

The internal equivalent circuit of the analog input pins is shown in Figure 9.5. The higher the output impedance of the analog input source, the more susceptible it becomes to noise. Therefore, make sure the output impedance of the signal source in your design is 5 K $\Omega$  or less. It is recommended that a capacitor be attached externally.



Note): I = 8 to 0

# Figure 9.5 Analog Input Equivalent Circuit and Example of Input Pin Processing

# Page: 123 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 10. Timer / Counter

# 10.1 Watchdog Timer/ Watchdog Timer2 (WDT/WDT2)

Because the WDT/WDT2 of MQ6812/MQ6821 are fixed and cannot be stopped , please clear WDT/WDT2 per 1.5 second at lease.

The watchdog timer is a fail-safe system to detect rapidly the CPU malfunctions such as endless loops due to spurious noises or the deadlock conditions, and return the CPU to a system recovery routine.

The watchdog timer signals used for detecting malfunctions can be programmed as watchdog interrupt request signals or watchdog timer reset signals.

The watchdog timer2(WDT2) use internal low-frequency clock. The counter value of WDT2 is 0xFFFF, which is fixed. The WDT2 clear function is the same as watchdog timer (WDT).

Note): Care must be taken in system designing since the watchdog timer may not fulfill its functions due to disturbing noise and other effects.

# 10.1.1 Configuration



Figure 10.1 Watchdog Timer Configuration

# Page: 124 / 278

# 10.1.2 Control

The watchdog timer is controlled by the watchdog timer control register (WDCTR), the watchdog timer control code register (WDCDR), the watchdog timer counter monitor (WDCNT) and the watchdog timer status (WDST).

The watchdog timer is controlled by the watchdog timer control code register (WDCDR).

The watchdog timer/ watchdog timer2 is enabled automatically just after the warm-up operation that follows reset is finished.

## Watchdog Timer Control Register

| WDCTR<br>(0x0FD4) | 7 | 6 | 5     | 4    | 3 | 2    | 1 | 0      |
|-------------------|---|---|-------|------|---|------|---|--------|
| Bit Symbol        | - | - | WDTEN | WDTW |   | WDTT |   | WDTOUT |
| Read/Write        | R | R | R/W   | R/W  |   | R/   | W | R/W    |
| After reset       | 1 | 0 | 1     | 0    | 0 | 1    | 1 | 0      |

| WDTEN  | Enable / disable the watch-<br>dog timer                     | 0: Disab<br>1: Enabl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                     |                     |  |  |
|--------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------|---------------------|--|--|
| WDTW   | Set the clear time of the 8-bit<br>up counter.               | <ul> <li>00: The 8-bit up counter is cleared by writing the clear code at any point within the overflow time of the 8-bit up counter.</li> <li>01: A watchdog timer interrupt request is generated by writing the clear code at a point within the first quarter of the overflow time of the 8-bit up counter. The 8-bit up counter is cleared by writing the clear code after the first quarter of the overflow time has elapsed.</li> <li>10: A watchdog timer interrupt request is generated by writing the clear code at a point within the first half of the overflow time of the 8-bit up counter. The 8-bit up counter is cleared by writing the clear code at a point within the first half of the overflow time of the 8-bit up counter. The 8-bit up counter is cleared by writing the clear code after the first half of the overflow time has elapsed.</li> <li>11: A watchdog timer interrupt request is generated by writing the clear code at a point within the first three quarters of the overflow time of the 8-bit up counter. The 8-bit up counter is cleared by writing the clear code at a point within the first three quarters of the overflow time of the 8-bit up counter. The 8-bit up counter is cleared by writing the clear code at a point within the first three quarters of the overflow time of the 8-bit up counter. The 8-bit up counter is cleared by writing the clear code at a point within the first three quarters of the overflow time have elapsed.</li> </ul> |                        |                     |                     |  |  |
|        |                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | NORMA                  | L mode              | SLOW mode           |  |  |
|        |                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DV9CK=0                | DV9CK=1             | see mode            |  |  |
| WDTT   | Set the overflow time of the 8-<br>bit up counter.           | 00:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2 <sup>18</sup> /fcgck | 2 <sup>11</sup> /fs | 2 <sup>11</sup> /fs |  |  |
|        |                                                              | 01:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2 <sup>20/</sup> fcgck | 2 <sup>13</sup> /fs | 2 <sup>13</sup> /fs |  |  |
|        |                                                              | 10:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2 <sup>22</sup> /fcgck | 2 <sup>15</sup> /fs | 2 <sup>15</sup> /fs |  |  |
| WDTOUT | Select an overflow detection signal of the 8-bit up counter. | 0 : Watchdog timer interrupt request signal<br>1 : Watchdog timer reset request signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                        |                     |                     |  |  |

#### Note 1): fcgck, Gear clock [Hz]; fs, Low frequency clock [Hz]

Note 2]: WDCTR <WDTW>, WDCTR <WDTT> and WDCTR <WDTOUT> cannot be changed when WDCTR <WDTEN> is "1". If WDCTR <WDTEN> is "1", clear WDCTR <WDTEN> to "0" and write the disable code (0xB1) into WDCDR to disable the watchdog timer operation. Note that WDCTR <WDTW>, WDCTR <WDTT> and WDCTR <WDTOUT> can be changed at the same time as setting WDCTR <WDTEN> to "1".

# Page: 125 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

Note 3]: Bit 7 and bit 6 of WDCTR are read as "1" and "0" respectively.

#### Watchdog Timer Control Code Register

| WDCDR<br>(0x0FD5) | 7 | 6      | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|-------------------|---|--------|---|---|---|---|---|---|--|--|
| Bit Symbol        |   | WDTCR2 |   |   |   |   |   |   |  |  |
| Read/Write        |   | W      |   |   |   |   |   |   |  |  |
| After reset       | 0 | 0      | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

|        |                                     | 0x4E: Clear the watchdog timer/ the watchdog timer2.<br>(clear code)                                                               |
|--------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| WDTCR2 | Write watchdog timer control codes. | 0xB1: Disable the watchdog timer operation and clear<br>the 8-bit up counter when WDCTR <wdten> is "0".<br/>(disable code)</wdten> |
|        |                                     | Others: Invalid                                                                                                                    |

#### 8-bit Up Counter Monitor

| WDCNT<br>(0x0FD6) | 7 | 6     | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|-------------------|---|-------|---|---|---|---|---|---|--|--|
| Bit Symbol        |   | WDCNT |   |   |   |   |   |   |  |  |
| Read/Write        |   | R     |   |   |   |   |   |   |  |  |
| After reset       | 0 | 0     | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

| WDCNT | Monitor the count value of the 8-bit up counter. | The count value of the 8-bit up counter is read. |
|-------|--------------------------------------------------|--------------------------------------------------|
|-------|--------------------------------------------------|--------------------------------------------------|

Note 1): WDCNT is only use for the watchdog timer/WDT). The counter value of watchdog timer2/WDT2/ is "0xFFF", cannot be changed by register.

#### Watchdog Timer Status

| WDST<br>(0x0FD7) | 7 | 6 | 5 | 4 | 3 | 2       | 1       | 0     |
|------------------|---|---|---|---|---|---------|---------|-------|
| Bit Symbol       | - | - | - | - | - | WINTST2 | WINTST1 | WDTST |
| Read/Write       | R | R | R | R | R | R       | R       | R     |
| After reset      | 0 | 1 | 0 | 1 | 1 | 0       | 0       | 1     |

| WINTST2  | Watchdog timer interrupt request signal factor status 2 | <ul><li>0: No watchdog timer interrupt request signal has occurred.</li><li>1: A watchdog timer interrupt request signal has occurred due to the overflow of the 8-bit up counter.</li></ul>                     |
|----------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WINTST 1 | Watchdog timer interrupt request signal factor status 1 | <ul><li>0: No watchdog timer interrupt request signal has occurred.</li><li>1: A watchdog timer interrupt request signal has occurred due to releasing of the 8-bit up counter outside the clear time.</li></ul> |
| WDTST    | Watchdog timer operating state status                   | 0: Operation disabled<br>1: Operation enabled                                                                                                                                                                    |

*Note 1): WDST <WINTST2> and WDST <WINTST1> are cleared to "0" by reading WDST. Note 2): Values after reset are read from bits 7 to 3 of WDST.* 

# 10.1.3 Function

The watchdog timer can detect the CPU malfunctions and deadlock by detecting the overflow of the 8-bit up counter and detecting releasing of the 8-bit up counter outside the clear time.

The watchdog timer stoppage and other abnormalities can be detected by reading the count value of the 8-bit up counter at random times and comparing the value to the last read value.

Set the clear code "0x4E" to WDCDR register, would clear the watchdog timer(WDT)/ the watchdog timer2(WDT2) at the same time.

The counter is different between the watchdog timer(WDT) and the watchdog timer2(WDT2). The counter value of the watchdog timer2(WDT2) is 0xFFF, and this values cannot be changed by register.

# 10.1.3.1 Setting of Enabling / Disabling the Watchdog Timer Operation

Setting WDCTR <WDTEN> to "1" enables the watchdog timer operation, and the 8-bit up counter starts counting the source clock.

WDCTR <WDTEN> is initialized to "1" after the warm-up operation that follows reset is released. This means that the watchdog timer is enabled.

To disable the watchdog timer operation, clear WDCTR <WDTEN> to "0" and write 0xB1 into WDCDR. Disabling the watchdog timer operation clears the 8-bit up counter to "0".

Note): If the overflow of the 8-bit up counter occurs at the same time as 0xB1 (disable code) is written into WDCDR with WDCTR <WDTEN> set at "1", the watchdog timer operation is disabled preferentially and the overflow detection is not executed.

To re-enable the watchdog timer operation, set WDCTR <WDTEN> to "1". There is no need to write a control code into WDCDR.

# Page: 127 / 278

# 汉芝电子股份有限公司

No. : TDDS01-M6812-EN

iMQ Technology Inc.

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1



## Figure 10.2 WDCTR < WDTEN> Set Timing and Overflow Time

Note): The 8-bit up counter source clock operates out of synchronization with WDCTR <WDTEN>. Therefore, the first overflow time of the 8-bit up counter after WDCTR <WDTEN> is set to "1" may get shorter by a maximum of 1 source clock. The 8-bit up counter must be cleared within the period of the overflow time minus 1 source clock cycle.

# 10.1.3.2 Setting the Clear Time of the 8-bit Up Counter

WDCTR <WDTW> sets the clear time of the 8-bit up counter.

When WDCTR <WDTW> is "00", the clear time is equal to the overflow time of the 8-bit up counter, and the 8-bit up counter can be cleared at any time.

When WDCTR <WDTW> is not "00", the clear time is fixed to only a certain period within the overflow time of the 8-bit up counter. If the operation for releasing the 8-bit up counter is attempted outside the clear time, a watchdog timer interrupt request signal occurs.

At this time, the watchdog timer is not cleared but continues counting. If the 8-bit up counter is not cleared within the clear time, a watchdog timer reset request signal or a watchdog timer interrupt request signal occurs due to the overflow, depending on the WDCTR <WDTOUT> setting.



## Figure 10.3 WDCTR <WDTW> and the 8-bit Up Counter Clear Time

# Page: 128 / 278

# 10.1.3.3 Setting the Overflow Time of the 8-bit Up Counter

WDCTR <WDTT> sets the overflow time of the 8-bit up counter.

When the 8-bit up counter overflows, a watchdog timer reset request signal or a watchdog timer interrupt request signal occurs, depending on the WDCTR <WDTOUT> setting.

If the watchdog timer interrupt request signal is selected as the malfunction detection signal, the watchdog counter continues counting, even after the overflow has occurred.

The watchdog timer temporarily stops counting up in the STOP mode (including warm-up) or in the IDLE / SLEEP mode, and restarts counting up after the STOP / IDLE / SLEEP mode is released. To prevent the 8-bit up counter from overflowing immediately after the STOP / IDLE / SLEEP mode is released, it is recommended to clear the 8-bit up counter before the operation mode is changed.

|      | Watchdog timer overflow time [s] |           |         |  |  |  |  |
|------|----------------------------------|-----------|---------|--|--|--|--|
| WDTT | NORMA                            | SLOW      |         |  |  |  |  |
|      | DV9CK = 0                        | DV9CK = 1 | mode    |  |  |  |  |
| 00   | 32.77 m                          | 62.50 m   | 62.50 m |  |  |  |  |
| 01   | 131.1 m                          | 250.0 m   | 250.0 m |  |  |  |  |
| 10   | 524.3 m                          | 1.000     | 1.000   |  |  |  |  |
| 11   | 2.097                            | 4.000     | 4.000   |  |  |  |  |

# Table 10.1 Watchdog Timer Overflow Time (fcgck=8.0 MHz; fs=32.768 KHz)

Note): The 8-bit up counter source clock operates out of synchronization with WDCTR <WDTEN>. Therefore, the first overflow time of the 8-bit up counter after WDCTR <WDTEN> is set to "1" may get shorter by a maximum of 1 source clock. The 8-bit up counter must be cleared within a period of the overflow time minus 1 source clock cycle.

# 10.1.3.4 Setting an Overflow Detection Signal of the 8-bit Up Counter

WDCTR <WDTOUT> selects a signal to be generated when the overflow of the 8-bit up counter is detected.

(a) When Watchdog Timer Interrupt Request Signal is Selected (as WDCTR <WDTOUT> is "0") Releasing WDCTR <WDTOUT> to "0" causes a watchdog timer interrupt request signal to occur when the 8-bit up counter overflows.

A watchdog timer interrupt is a non-maskable interrupt, and its request is always accepted, regardless of the interrupt master enable flag (IMF) setting.

Note): When a watchdog timer interrupt is generated while another interrupt, including a watchdog timer interrupt, is already accepted, the new watchdog timer interrupt is processed immediately and the preceding interrupt is put on hold. Therefore, if watchdog timer interrupts are generated continuously without execution of the RETN instruction, too many levels of nesting may cause a malfunction of the microcontroller.

# Page: 129 / 278

# (b) When Watchdog Timer Reset Request Signal is Selected (as WDCTR <WDTOUT> is "1") Setting WDCTR <WDTOUT> to "1" causes a watchdog timer reset request signal to occur when the 8-bit up counter overflows.

This watchdog timer reset request signal resets the MQ8S MCU series IC, and starts the warmup operation.

# 10.1.3.5 Writing the Watchdog Timer Control Codes

The watchdog timer control codes are written into WDCDR.

By writing 0x4E (clear code) into WDCDR, the 8-bit up counter is cleared to "0" and continues counting the source clock.

When WDCTR <WDTEN> is "0", writing 0xB1 (disable code) into WDCDR disables the watchdog timer operation.

To prevent the 8-bit up counter from overflowing, clear the 8-bit up counter in a period shorter than the overflow time of the 8-bit up counter and within the clear time.

By designing the program so that no overflow will occur, the program malfunctions and deadlock can be detected through interrupts generated by watchdog timer interrupt request signals.

By applying a reset to the microcomputer using watchdog timer reset request signals, the CPU can be restored from malfunctions and deadlock.

# 10.1.3.6 Reading the 8-bit Up Counter

The counter value of the 8-bit up counter can be read by reading WDCNT.

The stoppage of the 8-bit up counter can be detected by reading WDCNT at random times and comparing the value to the last read value.

# 10.1.3.7 Reading the Watchdog Timer Status

The watchdog timer status can be read at WDST.

WDST <WDTST> is set to "1" when the watchdog timer operation is enabled, and it is cleared to "0" when the watchdog timer operation is disabled.

WDST <WINTST2> is set to "1" when a watchdog timer interrupt request signal occurs due to the overflow of the 8-bit up counter.

WDST <WINTST1> is set to "1" when a watchdog timer interrupt request signal occurs due to the

# Page: 130 / 278

| 汉芝电子股份有限公司            |                                       |                |
|-----------------------|---------------------------------------|----------------|
| iMQ Technology Inc.   |                                       |                |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

operation for releasing the 8-bit up counter outside the clear time.

You can know which factor has caused a watchdog timer interrupt request signal by reading WDST 
WINTST2> and WDST 
WINTST1> in the watchdog timer interrupt service routine.

WDST <WINTST2> and WDST <WINTST1> are cleared to "0" when WDST is read. If WDST is readatthe same time as the condition for turning WDST <WINTST2> or WDST <WINTST1> to "1" issatisfied,WDST <WINTST2> or WDST <WINTST1> is set to "1", rather than being cleared.



# 10.1.3.8 Read the counter value of WDT2 and the clear the WDT2

The counter is different between the watchdog timer(WDT) and the watchdog timer2(WDT2). The counter value of the watchdog timer2(WDT2) is 0xFFF, and this values cannot be changed by register.

Set the clear code "0x4E" to WDCDR register, would clear the watchdog timer(WDT)/ the watchdog timer2(WDT2) at the same time.

# Page: 131/ 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 10.2 Divider Output (DVOB)

This function outputs approximately 50% duty pulses that can be used to drive the piezoelectric buzzer or other device.

# 10.2.1 Configuration



Figure 10.5 Divider Output

# 10.2.2 Control

The divider output is controlled by the divider output control register (DVOCR).

#### Divider Output Control Register

| DVOCR<br>(0x0038) | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0 |
|-------------------|---|---|---|---|---|-------|-------|---|
| Bit Symbol        | - | - | - | - | - | DVOEN | DVOCK |   |
| Read/Write        | R | R | R | R | R | R/W   | R/W   |   |
| After reset       | 0 | 0 | 0 | 0 | 0 | 0     | 0     | 0 |

| DVOEN | Enable / disable the divider output | 0: Disab<br>1: Enab |                       |                   |                   |
|-------|-------------------------------------|---------------------|-----------------------|-------------------|-------------------|
|       |                                     |                     | Normal 1/2, I         | DLE 1/2 mode      | SLOW 1/2 mode     |
|       |                                     |                     | DV9CK=0               | DV9CK=1           | SLEEP 1/2 mode    |
| DVOCK | Select the divider output frequency | 00:                 | fcgck/2 <sup>12</sup> | fs/2 <sup>5</sup> | fs/2 <sup>5</sup> |
| DVOCK | Unit: [Hz]                          | 01:                 | fcgck/2 <sup>11</sup> | fs/2 <sup>4</sup> | fs/2 <sup>4</sup> |
|       |                                     | 10:                 | fcgck/2 <sup>10</sup> | fs/2 <sup>3</sup> | fs/2 <sup>3</sup> |
|       |                                     |                     | fcgck/2 <sup>9</sup>  | Reserved          | Reserved          |

Note 1): fcgck: Gear clock [Hz], fs: Low-frequency clock [Hz]

Note 2]: DVOCR <DVOEN> is cleared to "0" when the operation is switched to STOP or IDLE0/SLEEP0 mode. DVOCR <DVOCK> holds the value.

Note 3]: When SYSCR1 <DV9CK> is "1" in the NORMAL 1/2 or IDLE 1/2 mode, the DVO frequency is subject to some

fluctuations to synchronize fs and fcgck.

Note 4]: Bits 7 to 3 of DVOCR are read as "0".

# Page: 132 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 10.2.3 Function

Select the divider output frequency at DVOCR < DVOCK>.

The divider output is enabled by setting DVOCR <DVOEN> to "1". Then, the rectangular waves selected by DVOCR <DVOCK> are output from DVOB pin.

It is disabled by clearing DVOCR < DVOEN> to "0". And DVOB pin keeps "H" level.

When the operation is changed to STOP or IDLE0 / SLEEP0 mode, DVOCR <DVOEN> is cleared to "0" and the DVOB pin outputs the "H" level.

The divider output source clock operates, regardless of the value of DVOCR <DVOEN>.

Therefore, the frequency of the first divider output after DVOCR <DVOEN> is set to "1" is not the frequency set at DVOCR <DVOCK>.

When the operation is changed to the software, STOP or IDLE0/SLEEP0 mode is activated and DVOCR <DVOEN> is cleared to "0", the frequency of the divider output is not the frequency set at DVOCR <DVOCK>.



Figure 10.6 Divider Output Timing

When the operation is changed from NORMAL mode to SLOW mode or from SLOW mode to NORMAL mode, the divider output frequency does not reach the expected value due to synchronization of the gear clock (fcqck) and the low-frequency clock (fs).

|       | Divider output frequency [Hz] |                   |          |  |  |  |  |  |
|-------|-------------------------------|-------------------|----------|--|--|--|--|--|
| DVOCK | NORMAL 1/2,                   | SLOW1/2, SLEEP1/2 |          |  |  |  |  |  |
|       | DV9CK = 0                     | DV9CK = 1         | mode     |  |  |  |  |  |
| 00    | 1.953 k                       | 1.024 k           | 1.024 k  |  |  |  |  |  |
| 01    | 3.906 k                       | 2.048 k           | 2.048 k  |  |  |  |  |  |
| 10    | 7.813 k                       | 4.096 k           | 4.096 k  |  |  |  |  |  |
| 11    | 15.625 k                      | Reserved          | Reserved |  |  |  |  |  |

Table 10.2 Divider Output Frequency (Example: fcgck = 8.0 MHz, fs = 32.768 kHz)

## Page: 133/ 278

# 10.3 Time Base Timer (TBT)

The time base timer generates the time base for key scanning, dynamic display and other processes. It also provides a time base timer interrupt (INTTBT) in a certain cycle.

#### 10.3.1 Configuration



## Figure 10.7 Time Base Timer Configuration

# 10.3.2 Control

The time base timer is controlled by the time base timer control register (TBTCR).

| TBTCR<br>(0x0039) | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0 |
|-------------------|---|---|---|---|-------|-------|---|---|
| Bit Symbol        | - | - | - | - | TBTEN | ТВТСК |   |   |
| Read/Write        | R | R | R | R | R/W   | R/W   |   |   |
| After reset       | 0 | 0 | 0 | 0 | 0     | 0     | 0 | 0 |

# Time Base Timer Control Register

| TBTEN | Enable / disable the time base timer interrupt requests. | 0: Disab<br>1: Enabl |                       |                    |                    |
|-------|----------------------------------------------------------|----------------------|-----------------------|--------------------|--------------------|
|       |                                                          |                      | Normal 1/2, I         | DLE 1/2 mode       | SLOW 1/2 mode      |
|       |                                                          |                      | DV9CK=0               | DV9CK=1            | SLEEP 1/2 mode     |
|       |                                                          | 000:                 | fcgck/2 <sup>22</sup> | fs/2 <sup>15</sup> | fs/2 <sup>15</sup> |
|       |                                                          | 001:                 | fcgck/2 <sup>20</sup> | fs/2 <sup>13</sup> | fs/2 <sup>13</sup> |
| ТВТСК | Select the time base timer interrupt frequency           | 010:                 | fcgck/2 <sup>15</sup> | fs/2 <sup>8</sup>  | Reserved           |
| IDICK | Unit: [Hz]                                               | 011:                 | fcgck/2 <sup>13</sup> | fs/2 <sup>6</sup>  | Reserved           |
|       |                                                          | 100:                 | fcgck/2 <sup>12</sup> | fs/2 <sup>5</sup>  | Reserved           |
|       |                                                          | 101:                 | fcgck/2 <sup>11</sup> | fs/2 <sup>4</sup>  | Reserved           |
|       |                                                          |                      | fcgck/2 <sup>10</sup> | fs/2 <sup>3</sup>  | Reserved           |
|       |                                                          | 111:                 | fcgck/2 <sup>8</sup>  | Reserved           | Reserved           |

Note 1): fcgck : Gear clock [Hz], fs : Low-frequency clock [Hz]

Note 2]: When the operation is changed to the STOP mode, TBTCR <TBTEN> is cleared to "0" and TBTCR <TBTCK> maintains the value.

# Page: 134 / 278

iMQ reserves the right to change the information in this document without prior notice. Please contact iMQ to obtain the latest version of indemnify and hold harmless iMQ from any and all damages, claims, suits or expenses resulting from such use. Note 3): TBTCR <TBTCK> should be set when TBTCR <TBTEN> is "0". Note 4): When SYSCR1 <DV9CK> is "1" in the NORMAL 1/2 or IDLE1/2 mode, the interrupt request is subject to some fluctuations to synchronize fs and fcgck. Note 5): Bits 7 to 4 of TBTCR are read as "0".

# 10.3.3 Function

Select the source clock frequency for the time base timer by TBTCR <TBTCK>. TBTCR <TBTCK> should be changed when TBTCR <TBTEN> is "0". Otherwise, the INTTBT interrupt request is generated at unexpected timing.

Setting TBTCR <TBTEN> to "1" causes interrupt request signals to occur at the falling edge of the source clock. When TBTCR <TBTEN> is cleared to "0", no interrupt request signal will occur.

When the operation is changed to the STOP mode, TBTCR < TBTEN> is cleared to "0". The source clock of the time base timer operates regardless of the TBTCR <TBTEN> value.

A time base timer interrupt is generated at the first falling edge of the source clock after a time base timer interrupt request is enabled. Therefore, the period from the time TBTCR <TBTEN> is set to "1" to the time the first interrupt request occurs is shorter than the frequency period set at TBTCR <TBTCK>.



Figure 10.8 Time Base Timer Interrupt

When the operation is changed from NORMAL mode to SLOW mode or from SLOW mode to NORMAL mode, the interrupt request will not occur at the expected timing due to synchronization of the gear clock (fcgck) and the low-frequency clock (fs). It is recommended that the operation mode is changed when TBTCR <TBTEN> is "0".

# Page: 135 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| TRIOK | Tin                     | Time base timer interrupt frequency [Hz] |                        |  |  |  |  |  |  |
|-------|-------------------------|------------------------------------------|------------------------|--|--|--|--|--|--|
| TBTCK | NORMAL1/2, IDLE1/2 mode | NORMAL1/2, IDLE1/2 mode                  | SLOW1/2, SLEEP1/2 mode |  |  |  |  |  |  |
|       | DV9CK = 0               | DV9CK = 1                                |                        |  |  |  |  |  |  |
| 000   | 1.91                    | 1                                        | 1                      |  |  |  |  |  |  |
| 001   | 7.63                    | 4                                        | 4                      |  |  |  |  |  |  |
| 010   | 244.14                  | 128                                      | Reserved               |  |  |  |  |  |  |
| 011   | 976.56                  | 512                                      | Reserved               |  |  |  |  |  |  |
| 100   | 1953.13                 | 1024                                     | Reserved               |  |  |  |  |  |  |
| 101   | 3906.25                 | 2048                                     | Reserved               |  |  |  |  |  |  |
| 110   | 7812.5                  | 4096                                     | Reserved               |  |  |  |  |  |  |
| 111   | 31250                   | Reserved                                 | Reserved               |  |  |  |  |  |  |

Table 10.3 Time Base Timer Interrupt Frequency (Example: fcgck = 8.0 MHz, fs = 32.768 kHz)

# 10.4 Real Time Clock (RTC)

The real time clock is a function that generates interrupt requests at certain intervals using the lowfrequency clock.

The number of interrupts is counted by the software to realize the clock function. The real time clock can be used only in the operation modes where the low-frequency clock oscillates, except for SLEEP0.

# 10.4.1 Configuration



Figure 10.9Real Time Clock

# 10.4.2 Control

The real time clock is controlled by following registers.

## Page: 136 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| .ow Power | Consum | otion | Register | 2 |
|-----------|--------|-------|----------|---|
|           |        |       |          |   |

| POFFCR2<br>(0x0F76) | 7     | 6 | 5     | 4 | 3 | 2 | 1 | 0      |
|---------------------|-------|---|-------|---|---|---|---|--------|
| Bit Symbol          | LCDEN | - | RTCEN | - | - | - | - | SIOOEN |
| Read/Write          | R/W   | R | R/W   | R | R | R | R | R/W    |
| After reset         | 0     | 0 | 0     | 0 | 0 | 0 | 0 | 0      |

| LCDEN  | LCD control  | 0: Disable<br>1: Enable |
|--------|--------------|-------------------------|
| RTCEN  | RTC control  | 0: Disable<br>1: Enable |
| SIO0EN | SIO0 control | 0: Disable<br>1: Enable |

#### **Real Time Clock Control Register**

| RTCCR<br>(0x0FC8) | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0      |
|-------------------|---|---|---|---|--------|---|---|--------|
| Bit Symbol        | - | - | - | - | RTCSEL |   |   | RTCRUN |
| Read/Write        | R | R | R | R | R/W    |   |   | R/W    |
| After reset       | 0 | 0 | 0 | 0 | 0 0 0  |   |   | 0      |

| RTCSEL | Selectstheinterruptgenerationinterval         | $\begin{array}{l} 000:2^{15}/fs(1.000[s]@fs=32.768kHz)\\ 001:2^{14}/fs(0.500[s]@fs=32.768kHz)\\ 010:2^{13}/fs(0.250[s]@fs=32.768kHz)\\ 011:2^{12}/fs(125.0[ms]@fs=32.768kHz)\\ 100:2^{11}/fs(62.50[ms]@fs=32.768kHz)\\ 101:2^{10}/fs(31.25[ms]@fs=32.768kHz)\\ 110:2^{9}/fs(15.62[ms]@fs=32.768kHz)\\ 111:2^{8}/fs(7.81[ms]@fs=32.768kHz)\\ \end{array}$ |
|--------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RTCRUN | Enables/disablestherealtimeclockoper<br>ation | 0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                  |

#### Note 1): fs: Low-frequency clock [Hz]

Note 2): RTCCR <RTCSEL> can be rewritten only when RTCCR <RTCRUN> is "0". If data is written into RTCCR <RTCSEL> when RTCCR <RTCRUN> is "1", the existing data remains effective. RTCCR <RTCSEL> can be rewritten at the same time as enabling the real time clock, but it cannot be rewritten at the same time as disabling the real time clock.

Note 3]: If the real time clock is enabled and when 1] SYSCR2 <XTEN> is cleared to "0" to stop the low-frequency clock oscillation circuit or 2] the operation is changed to the STOP mode or the SLEEPO mode, the data in RTCCR <RTCSEL> is maintained and RTCCR <RTCRUN> is cleared to "0".

# 10.4.3 Function

#### 10.4.3.1 Low Power Consumption Function

Real time clock has the low power consumption registers (POFFCR2) that save power when the real time clock is not being used. Setting POFFCR2 <RTCEN> to "0" disables the basic clock supply

# Page: 137 / 278

to real time clock to save power. Note that this renders the real time clock unusable. Setting POFFCR2 <RTCEN> to "1" enables the basic clock supply to real time clock and allows the real time clock to operate.

After reset, POFFCR2 <RTCEN> are initialized to "0", and this renders the real time clock unusable. When using the real time clock for the first time, be sure to set POFFCR2 <RTCEN> to "1" in the initial setting of the program (before the real time clock control registers are operated).

Do not change POFFCR2 <RTCEN> to "0" during the real time clock operation. Otherwise real time clock may operate unexpectedly.

# 10.4.3.2 Enabling / Disabling the Real Time Clock Operation

Setting RTCCR <RTCRUN> to "1" enables the real time clock operation. Setting RTCCR <RTCRUN> to "0" disables the real time clock operation. RTCCR <RTCRUN> is cleared to "0" just after reset release.

# 10.4.3.3 Selecting the Interrupt Generation Interval

The interrupt generation interval can be selected at RTCCR <RTCSEL>. RTCCR <RTCSEL> can be rewritten only when RTCCR <RTCRUN> is "0". If data is written into RTCCR <RTCSEL> when RTCCR <RTCRUN> is "1", the existing data remains effective.

RTCCR <RTCSEL> can be rewritten at the same time as enabling the real time clock operation, but it cannot be re-written at the same time as disabling the real time clock operation.

# 10.4.4 Real Time Clock Operation

# 10.4.4.1 Enabling the Real Time Clock Operation

Set the interrupt generation interval to RTCCR <RTCSEL>, and at the same time, set RTCCR <RTCRUN> to "1". When RTCCR <RTCRUN> is set to "1", the binary counter for the real time clock starts counting of the low-frequency clock. When the interrupt generation interval selected at RTCCR <RTCSEL> is reached, a real time clock interrupt request (INTRTC) is generated and the counter continues counting.

# 10.4.4.2. Disabling the Real Time Clock Operation

Clear RTCCR <RTCRUN> to "0". When RTCCR <RTCRUN> is cleared to "0", the binary counter for the real time clock is cleared to "0" and stops counting of the low-frequency clock.

# Page: 138 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 10.5 10-bit Timer Counters

MQ6812/MQ6821 contains 6 channels of high-performance 10-bit timer counters 00, 01, 02,03,04 and 05 (TCQ0). Each timer can be used for time measurement and pulse output with a prescribed width.

#### Please be noted.:

- 1. Only TCQ00,TCQ02,TCQ04 support double buffer register.
- 2. PPG pulse output do not support duty as 0% and 100%.

This chapter describes 2 channels of 10-bit timer counters 00 and 01. For 10-bit timer counters 02, 03, and 04,05, replace the SFR addresses and pin names as shown in Table 10.4 and Table 10.5.

#### Only TCQ00 (02,04) support double buffer ; TCQ01(03,05) do not support double buffer.

|                  | T0xREGL<br>(Address) | T0xREGH<br>(Address) | T0xPWML<br>(Address) | T0xPWMH<br>(Address) | T0xMOD<br>(Address) | T0xxCR<br>(Address) | Low power<br>consumption register |
|------------------|----------------------|----------------------|----------------------|----------------------|---------------------|---------------------|-----------------------------------|
| Timer counter 00 | T00REGL<br>(0x0F9C)  | T00REGH<br>(0x0F9D)  | T00PWML<br>(0x0FA0)  | T00PWMH<br>(0x0FA1)  | T00MOD<br>(0x002A)  | T001CR              | POFFCR0                           |
| Timer counter 01 | T01REGL<br>(0x0F9E)  | T01REGH<br>(0x0F9F)  | T01PWML<br>(0x0FA2)  | T01PWMH<br>(0x0FA3)  | T01MOD<br>(0x002B)  | (0x002C)            | <tc001en></tc001en>               |
| Timer counter 02 | T02REGL<br>(0x0FA4)  | T02REGH<br>(0x0FA5)  | T02PWML<br>(0x0FA8)  | T02PWMH<br>(0x0FA9)  | T02MOD<br>(0x0F8C)  | T023CR              | POFFCR0                           |
| Timer counter 03 | T03REGL<br>(0x0FA6)  | T03REGH<br>(0x0FA7)  | T03PWML<br>(0x0FAA)  | T03PWMH<br>(0x0FAB)  | T03MOD<br>(0x0F8D)  | (0x0F8E)            | <tc023en></tc023en>               |
| Timer counter 04 | T04REGL<br>(0x0FB0)  | T04REGH<br>(0x0FB1)  | T04PW/ML<br>(0x0FB4) | T04PWMH<br>(0x0FB5)  | T04MOD<br>(0x0FB8)  | T045CR              | POFFCR0                           |
| Timer counter 05 | T05REGL<br>(0x0FB2)  | T05REGH<br>(0x0FB3)  | T05PW/ML<br>(0x0FB6) | T05PWMH<br>(0x0FB7)  | T05MOD<br>(0x0FB9)  | (0x0FBA)            | <tc045en></tc045en>               |

#### Table 10.4 SFR Address Assignment

|                  | PPG Output Pin |
|------------------|----------------|
| Timer counter 00 | PPG00B pin     |
| Timer counter 01 | PPG01B pin     |
| Timer counter 02 | PPG02B pin     |
| Timer counter 03 | PPG03B pin     |
| Timer counter 04 | PPG04B pin     |
| Timer counter 05 | PPG0%B pin     |

Table 10.5 Pin Names

## Page: 139/ 278

# 10.5.1 Control

#### 10.5.1.1 **Timer Counter 00**

The timer counter 00 is controlled by the timer counter 00 mode register (T00MOD) and four 10bit timer registers (TOOREGL/TOOREGH and TOOPWML/TOOPWMH).

#### Timer Register 00(L)

| TOOREGL<br>(0x0F9C) | 7   | 6       | 5   | 4   | 3   | 2   | 1   | 0   |  |
|---------------------|-----|---------|-----|-----|-----|-----|-----|-----|--|
| Bit Symbol          |     | TOOREGL |     |     |     |     |     |     |  |
| Read/Write          | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |
| After reset         | 1   | 1       | 1   | 1   | 1   | 1   | 1   | 1   |  |

## Timer Register 00(H)

| TOOREGH<br>(0x0F9D) | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    |
|---------------------|----|----|----|----|----|----|------|------|
| Bit Symbol          | -  | -  | -  | -  | -  | -  | TOOR | REGH |
| Read/Write          | R  | R  | R  | R  | R  | R  | R/W  | R/W  |
| After reset         | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

#### Timer Register 00(H)

| T00PW/ML<br>(0x0FA0) | 7   | 6       | 5   | 4   | 3   | 2   | 1   | 0   |  |
|----------------------|-----|---------|-----|-----|-----|-----|-----|-----|--|
| Bit Symbol           |     | TOOPWML |     |     |     |     |     |     |  |
| Read/Write           | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |
| After reset          | 1   | 1       | 1   | 1   | 1   | 1   | 1   | 1   |  |

#### Timer Register 00(L)

| T00PW/MH<br>(0x0FA1) | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8   |
|----------------------|----|----|----|----|----|----|------|-----|
| Bit Symbol           | -  | -  | -  | -  | -  | -  | TOOP | ₩МН |
| Read/Write           | R  | R  | R  | R  | R  | R  | R/W  | R/W |
| After reset          | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   |

Note]: Because PPG pulse output do not support duty as 0% and 100%. Please set TOOPW/M as 0 < TOOPW/M < TOOREG.

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| T00MOD<br>(0x002A) | 7    | 6    | 5    | 4   | 3   | 2    | 1   | 0   |
|--------------------|------|------|------|-----|-----|------|-----|-----|
| Bit Symbol         | TFF0 | DBE0 | ТСКО |     |     | EIN0 | TC  | M0  |
| Read/Write         | R/W  | R/W  | R/W  | R/W | R/W | R/W  | R/W | R/W |
| After reset        | 1    | 1    | 0    | 0   | 0   | 0    | 0   | 0   |

| TFF0   | Timer F/F0 control                        | 0: Clear<br>1: Set |                                                                                                                            |                        |                   |  |  |  |
|--------|-------------------------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------|------------------------|-------------------|--|--|--|
| DBE0   | Double buffer control                     |                    | isable the double buffer<br>nable the double buffer                                                                        |                        |                   |  |  |  |
|        |                                           |                    | Normal 1/2, IE<br>SYSCR1                                                                                                   | DLE 1/2 mode<br>SYSCR1 | SLOW 1/2 mode     |  |  |  |
|        |                                           |                    | <dv9ck>=0</dv9ck>                                                                                                          | <dv9ck>=1</dv9ck>      | SLEEP 1 mode      |  |  |  |
|        |                                           | 000:               | fcgck/2 <sup>4</sup>                                                                                                       | fcgck/2 <sup>4</sup>   |                   |  |  |  |
|        |                                           | 001:               | fcgck/2 <sup>2</sup>                                                                                                       | fcgck/2 <sup>2</sup>   |                   |  |  |  |
|        |                                           | 010:               | fcgck/2                                                                                                                    | fcgck/2                |                   |  |  |  |
| TCK0   | Operation clock selection                 | 011:               | fcgck                                                                                                                      | fcgck                  | fs/2 <sup>2</sup> |  |  |  |
|        |                                           | 100:               | fcgck/2 <sup>4</sup>                                                                                                       | fcgck/2 <sup>4</sup>   | -                 |  |  |  |
|        |                                           | 101:               | fcgck/2 <sup>2</sup>                                                                                                       | fcgck/2 <sup>2</sup>   | -                 |  |  |  |
|        |                                           | 110:               | fcgck/2                                                                                                                    | fcgck/2                | -                 |  |  |  |
|        |                                           | 111:               | fcgck                                                                                                                      | fcgck                  | fs/2 <sup>2</sup> |  |  |  |
|        |                                           | Other              |                                                                                                                            | System reserv          | ved               |  |  |  |
| EINO   | Selection for using external source clock | 1: Select          | Select the internal clock as the source clock.<br>Select an external clock a s the source clock. (the f<br>f the TC00 pin) |                        |                   |  |  |  |
|        |                                           | 00:                | 10-bit timer / ev                                                                                                          | vent counter mo        | odes              |  |  |  |
| тсмо   | Operation mode selection                  | 01:                | 10-bit timer / e                                                                                                           | vent counter mo        | odes              |  |  |  |
| TCIVIU | Operation mode selection                  | 10:                | 10-bit program                                                                                                             | mable pulse ger        | nerate (PPG) mode |  |  |  |
|        |                                           | 11:                | 10-bit program                                                                                                             | mable pulse ger        | nerate (PPG) mode |  |  |  |

Note 1): fcgck: Gear clock [Hz], fs: Low-frequency clock [Hz]

Note 2]: Set T00MOD while the timer is stopped. Writing data into T00MOD is invalid during the timer operation. Note 3]: In the 10-bit timer/event modes, the TFF0 setting is invalid. In this mode, when the PPG0B pins are set as the function output pins in the port setting, the pins always output the "H" level.

Note 4/: When EIN0 is set to "1" and the external clock input is selected as the source clock, the TCK0 setting is ignored.

## 10.5.1.2 Timer Counter 01

Timer counter 01 is controlled by timer counter 01 mode register (T01MOD) and four 10-bit timer registers (T01REGL/ T01REGH and T01PWML/T01PWMH).

| Timer Regist        |     |                             |   |   |   |   |   |   |  |
|---------------------|-----|-----------------------------|---|---|---|---|---|---|--|
| T01REGL<br>(0x0F9E) | 7   | 6                           | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Bit Symbol          |     | T01REGL                     |   |   |   |   |   |   |  |
| Read/Write          | R/W | R/W R/W R/W R/W R/W R/W R/W |   |   |   |   |   |   |  |
| After reset         | 1   | 1                           | 1 | 1 | 1 | 1 | 1 | 1 |  |

#### Timer Register 01/L)

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## Timer Register 01(H)

| T01REGH<br>(0x0F9F) | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8   |
|---------------------|----|----|----|----|----|----|------|-----|
| Bit Symbol          | -  | -  | -  | -  | -  | -  | TOIR | EGH |
| Read/Write          | R  | R  | R  | R  | R  | R  | R/W  | R/W |
| After reset         | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   |

## Timer Register 01(L)

| T01PWML<br>(0x0FA2) | 7   | 6       | 5   | 4   | 3   | 2   | 1   | 0   |  |
|---------------------|-----|---------|-----|-----|-----|-----|-----|-----|--|
| Bit Symbol          |     | T01PWML |     |     |     |     |     |     |  |
| Read/Write          | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |
| After reset         | 1   | 1       | 1   | 1   | 1   | 1   | 1   | 1   |  |

#### Timer Register 01(H)

| T01PWMH<br>(0x0FA3) | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8   |
|---------------------|----|----|----|----|----|----|------|-----|
| Bit Symbol          | -  | -  | -  | -  | -  | -  | T01P | WМН |
| Read/Write          | R  | R  | R  | R  | R  | R  | R/W  | R/W |
| After reset         | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0   |

Note]: Because PPG pulse output do not support duty as 0% and 100%. Please set TOOPW/M as 0 < TOOPW/M < TOOREG.

#### Timer Counter 01 Mode Register

| T01MOD<br>(0x002B) | 7     | 6             | 5   | 4    | 3   | 2     | 1   | 0   |
|--------------------|-------|---------------|-----|------|-----|-------|-----|-----|
| Bit Symbol         | TFF 1 | -<br>(note 5) |     | TCK1 |     | EIN 1 | TC  | M1  |
| Read/Write         | R/W   | R             | R/W | R/W  | R/W | R     | R/W | R/W |
| After reset        | 1     | 0             | 0   | 0    | 0   | 0     | 0   | 0   |

| TFF 1  | Timer F/F1 control                        | 0: Clea<br>1: Set | r                                                       |                                                  |                       |  |  |
|--------|-------------------------------------------|-------------------|---------------------------------------------------------|--------------------------------------------------|-----------------------|--|--|
|        |                                           |                   | Normal 1/2,                                             | SLOW 1/2 mode                                    |                       |  |  |
|        |                                           |                   | SYSCR1 <dv9ck>=0</dv9ck>                                | SYSCR1 <dv9ck>=1</dv9ck>                         | SLEEP 1 mode          |  |  |
|        |                                           | 100:              | fcgck/2 <sup>4</sup>                                    | fcgck/2 <sup>4</sup>                             | -                     |  |  |
| TCK1   | Operation clock selection                 | 101:              | fcgck/2 <sup>2</sup>                                    | fcgck/2 <sup>2</sup>                             | -                     |  |  |
|        |                                           | 110:              | fcgck/2                                                 | -                                                |                       |  |  |
|        |                                           | 111:              | fcgck                                                   | fs/2 <sup>2</sup>                                |                       |  |  |
|        |                                           | other             | System reserved                                         |                                                  |                       |  |  |
| EIN1   | Selection for using external source clock |                   | t the internal clock as th<br>t an external clock as th | e source clock.<br>e source clock.(the falling e | edge of the TC01 pin) |  |  |
|        |                                           | 00:               | 1                                                       | 0-bit timer/eventcountermode                     | 25                    |  |  |
| TCM1   | Operation mode selection                  | 01:               | 10-bit timer/eventcounter                               | rmodes                                           |                       |  |  |
| ICIVIT | Operation mode selection                  | 10:               | 10-bit programmable puls                                | e generate (PPG) mode                            |                       |  |  |
|        |                                           | 11:               | 10-bit programmable puls                                | e generate (PPG) mode                            |                       |  |  |

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Note 1]: fcgck: Gear clock [Hz], fs: Low-frequency clock [Hz]

Note 2]: Set T01MOD while the timer is stopped. Writing data into T01MOD is invalid during the timer operation. Note 3]: In the 10-bit timer/event modes, the TFF1 setting is invalid. In this mode, when the PPG1B pins are set as the function output pins in the port setting, the pins always output the "H" level.

Note 4): When EIN1 is set to "1" and the external clock input is selected as the source clock, the TCK1 setting is ignored. Note 5]: Only TCQ00 (02,04) support double buffer ; TCQ01(03,05) do not support double buffer.

## 10.5.1.3 Common to Timer Counters 00 and 01

Timer counters 00 and 01(02 and 03/04 and 05) have the low power consumption register (POFFCR0) and timer 00 and 01 control registers in common.

| POFFCR0<br>(0x0F74) | 7 | 6       | 5       | 4       | 3 | 2 | 1 | 0      |
|---------------------|---|---------|---------|---------|---|---|---|--------|
| Bit Symbol          | - | TC045EN | TC023EN | TC001EN | - | - | - | TCA0EN |
| Read/Write          | R | R/W     | R/W     | R/W     | R | R | R | R/W    |
| After reset         | 0 | 0       | 0       | 0       | 0 | 0 | 0 | 0      |

#### Low Power Consumption Register 0

| TC045EN | TCQ04, 05 control | 0: Disable<br>1: Enable |
|---------|-------------------|-------------------------|
| TC023EN | TCQ02, 03 control | 0: Disable<br>1: Enable |
| TC001EN | TCQ00, 01 control | 0: Disable<br>1: Enable |
| TCA0EN  | TCA0 control      | 0: Disable<br>1: Enable |

#### Timer 00 and 01 Control Register

| T001CR<br>(0x002C) | 7 | 6 | 5 | 4      | 3      | 2 | 1      | 0      |
|--------------------|---|---|---|--------|--------|---|--------|--------|
| Bit Symbol         | - | - | - | COMPSL | OUTAND | - | T01RUN | TOORUN |
| Read/Write         | R | R | R | R/W    | R/W    | R | R/W    | R/W    |
| After reset        | 0 | 0 | 0 | 0      | 0      | 0 | 0      | 0      |

| COMPSL | Timer 00/01 complementary<br>output control | 0: Output the timer 00 output from the PPG0B pins and the timer     |
|--------|---------------------------------------------|---------------------------------------------------------------------|
|        |                                             | 01 output from the PPG1B pins.                                      |
|        |                                             | 1: Output the timer 00 copmlemetary output from the PPG01B pins     |
|        |                                             | and the timer 00 output from the PPG00B pins.                       |
|        |                                             |                                                                     |
| OUTAND |                                             | 0: Output the timer 00 output from the PPG00B pins and the timer    |
|        | Timer 00 and 01 output control              | 01 output from the PPG01B pins.                                     |
|        |                                             |                                                                     |
|        |                                             | 1: Output a pulse that is a logical ANDed product of the outputs of |
|        |                                             | timer 00 and 01 from the PPG01B pins. Output the timer 00 output    |
|        |                                             | from the PPG00B pins                                                |
| TOIRUN | Timer 01 control (note 5)                   | 0: Stop and clear the timer                                         |
|        |                                             | 1: Start                                                            |

# 汉芝电子股份有限公司 iMO Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

| TOORUN | Timer 00 control | 0: Stop and clear the timer<br>1: Start |
|--------|------------------|-----------------------------------------|
|--------|------------------|-----------------------------------------|

Note 1): When STOP mode is started, TOORUN and TO1RUN are cleared to "0" and the timers stop. Set TOO1CR again to use timers 00 and 01 after STOP mode is released.

Note 2]: When a read instruction is executed on TOO1CR, bits 7~5 and Bit2 are read as "0".

Note 3): When OUTAND is "1", output is obtained from the PPG1B pins only. There is no timer output to the PPG0B pins. If the PPG0B pins are set as the function output pins in the port setting, the pins always output "H".

Note 4): OUTAND and COMPSL can be changed only when both TC01RUN and TC00RUN are "0". When either TC01RUN or TC00RUN is "1" or both are "1", the register values remain unchanged by executing write instructions on OUTAND and COMPSL. OUTAND and COMPSL can be changed at the same time as TC01RUN and TC00RUN are changed from "0" to "1".

Note 5): When T01RUN is "1" (start the timer 01), T00RUN should be set as "1".

# 10.5.1.4 Operation Modes and Usable Source Clocks

| T00MOD <tck0></tck0>     |              | 100                  | 101                  | 110     | 111                       |
|--------------------------|--------------|----------------------|----------------------|---------|---------------------------|
| Operation mode           |              | fcgck/2 <sup>4</sup> | fcgck/2 <sup>2</sup> | fcgck/2 | fcgck 或 fs/2 <sup>2</sup> |
| 10-bit<br>timer<br>modes | 10-bit timer | 0                    | 0                    | 0       | 0                         |
|                          | 10-bit PPG   | 0                    | 0                    | 0       | 0                         |

## Table 10.6 Operation Modes and Usable Source Clocks (NORMAL1/2 and IDLE1/2 Modes)

The operation modes of the 8-bit timers and the usable source clocks are listed below.

Note 1): •: Usable, -: Unusable

Note 2): When the low-frequency clock, fs, is not oscillating, it must not be selected as the source clock. If fs is selected when it is not oscillating, no source clock is supplied to the timer, and the timer remains stopped.

| T00MOD <tck0></tck0>     |              | 100 | 101 | 110 | 111               |
|--------------------------|--------------|-----|-----|-----|-------------------|
| Operation mode           |              | -   | -   | -   | fs/2 <sup>2</sup> |
| 10-bit<br>timer<br>modes | 10-bit timer | -   | -   | -   | 0                 |
|                          | 10-bit PPG   | -   | -   | -   | 0                 |

Table 10.7 Operation Modes and Usable Source Clocks (SLOW1/2 and SLEEP1 Modes)

Note 1): •: Usable, -: Unusable

# Page: 144 / 278

## 10.5.2 Low Power Consumption Function

Timer counters 00 and 01 have the low power consumption registers (POFFCR0) that save power when the timers are not used. Setting POFFCR0 <TC001EN> to "0" disables the basic clock supply to timer counters 00 and 01 to save power. Note that this renders the timers unusable. Setting POFFCR0 <TC001EN> to "1" enables the basic clock supply to timer counters 00 and 01 and allows the timers to operate.

After reset, POFFCR0 <TC001EN> are initialized to "0", and this makes the timers unusable. When using the timers for the first time, be sure to set POFFCR0 <TC001EN> to "1" in the initial setting of the program (before the timer control registers are operated).

Do not change POFFCR0 <TC001EN> to "0" during the timer operation. Otherwise timer counters 00 and 01 may operate unexpectedly.

### 10.5.3 Function

The 10-bit modes TC00 and TC01 include three operation modes: 10-bit timer mode, 10-bit programmable pulse generated output (PPG) mode and 10-bit complementary output mode. (The same to TC02,TC03,TC04 and TC05)

### 10.5.3.1 10-bit Timer Mode

In the 10-bit timer mode, the up counter counts up using the internal clock, and interrupts can be generated regularly at specified times. The operation of TCQ00 is described below, and the same applies to the operation of TCQ01, TCQ02, TCQ03, TCQ04 and TCQ05. (Replace TCQ00- by TCQ0x,  $x=1\sim5$ ).

### (a) Setting

TCQ00 is put into the 10-bit timer mode by setting T00MOD <TCM0> to "00" or "01". Select the source clock at T00MOD <TCK0>. Set the count value to be used for the match detection as an 10-bit value at the timer register T00REGL/ T00REGH.

Set T00MOD <DBE0> to "1" to use the double buffer. Only TCQ00,TCQ02,TCQ04 can use double buffer. TCQ01,TCQ03,TCQ05 cannot use double buffer.

Setting T001CR <T00RUN> to "1" starts the operation. After the timer is started, writing to T00MOD becomes invalid. Be sure to complete the required mode settings before starting the timer.

### (b) Operation

Setting T001CR <T00RUN> to "1" allows the 10-bit up counter to increment based on the selected internal source clock. When a match between the up counter value and the

## Page: 145 / 278

| 汉芝电子股份有限公司            |                                       |                |
|-----------------------|---------------------------------------|----------------|
| iMQ Technology Inc.   |                                       |                |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

T00REGL/TOOREGH set value is detected, an INTTC00 interrupt request is generated and the up counter is cleared to "0x00". After being cleared, the up counter restarts counting. Setting T001CR <T00RUN> to "0" during the timer operation makes the up counter stop counting and be cleared to "0x00".

#### (c) Double Buffer

The double buffer can be used for T00REGL/T00REGH by setting T00MOD <DBE0>. The double buffer is disabled by setting T00MOD <DBE0> to "0" or enabled by setting T00MOD <DBE0> to "1".

#### 1. When the Double Buffer is Enabled

When a write instruction is executed on TOOREGL/TOOREGH during the timer operation, the set value is initially stored in the double buffer, and TOOREGL/TOOREGH is not immediately updated. TOOREGL/TOOREGH compares the previous set value with the up counter value. When the values match, an INTTCO0 interrupt request is generated and the double buffer set value is stored in TOOREGL/TOOREGH. Subsequently, the match detection is executed using a new set value.

When a write instruction is executed on T00REGL/T00REGH while the timer is stopped, the set value is immediately stored in both the double buffer and T00REGL/T00REGH.

#### 2. When the Double Buffer is Disabled

When a write instruction is executed on T00REGL/T00REGH during the timer operation, the set value is immediately stored in T00REGL/T00REGH. Subsequently, the match detection is executed using a new set value.

If the value set to TOOREGL/TOOREGH is smaller than the up counter value, the match detection is executed using a new set value after the up counter overflows. Therefore, the interrupt request interval may be longer than the selected time. If the value set to TOOREGL/TOOREGH is equal to the up counter value, the match detection is executed immediately after data is written into TOOREGL/TOOREGH. Therefore, the interrupt request interval may not be an integral multiple of the source clock (Figure 10.11). Under TCQ01,TCQ03,TCQ05 operating, please avoid to change the setting(detail please refer to appendix D). Otherwise, Or use TCQ00,TCQ02,TCQ04 to enable the double buffer.

When a write instruction is executed on T00REGL/T00REGH while the timer is stopped, the set value is immediately stored in T00REGL/T00REGH.

When a read instruction is executed on T00REGL/T00REGH, the last value written into T00REGL/T00REGH is read out, regardless of the T00MOD <DBE0> setting.

## Page: 146 / 278

#### 汉芝电子股份有限公司 iMQ Technology Inc. No. : TDDS01-M6812-EN Name : MQ6812/MQ6821/MQ6822 Datasheet Version: V1.1 Timer start T001CR<T00RUN> T00MOD<DBE0> Source clock Counter 0 m-1 0 3 0 1 2 )) Counter clear Counter clear Write to T00REG Write m Write n Double buffer 2 m n TOOREG Match detection Match detection Match detection m 'n Reflected at the same time Reflected by as data is written into TOOREG an interrupt INTTC00 interrupt request while the timer is stopped When the double buffer is enabled (T00MOD<DBE0>="1"> Figure 10.10 Timer Mode Timing Chart (T00MOD<DBE0>="1") Note: T00REG=T00REGH/L No double buffer(TCQ01,TCQ03,TCQ05, or TCQ00,TCQ02,TCQ04 disable double buffer. New setting value is n, and when 1.Change the set value when timer is operating, the set value would be effective immediately. 2.According the setting timing , it may cause a longer period "1024+n". n is the set value of timer setting register already pass n to n+2, therefore the next interrupt point would count to n , after overflow occurs T001CR<T00RUN> T00MOD<DBE0> Source clock Counter ĎŮŹĴŦŴĸĸĸĸĸŧŴĸŧŶŧĨŶŎĹŹĴŦŴŴĸŴŶĸŸŶŶŴĨŴĊĹŹĴŦŴŴġŊŎĹŹĴŦŴŴĸŴŎĹŹĊ Interrupt poin Write to TOOREG TOOREG upt after overflow INTTCOD No double buffer or double buffer disable (T00MOD<DBE0>=0). Set the new value when the set value(n) of this period is passed. T001CR<T00RUN> T00MOD<DBE0; Source clock 0 1 2 3 4 (m1) 0 1 2 3 4 (m1) 0 1 2 3 (m1) 0 1 Counte rupt point, cou Write to TOOREG

No double buffer or double buffer disable (T00MOD<DBE0>=0). Set the new value when the set value(n) of this period is not over.

#### Figure 10.11 Timer Mode Timing Chart(T00MOD<DBE0>="0")

TOOREG

Note: T00REG=T00REGH/L

## Page: 147 / 278

| 汉芝电子股份有限公司<br>iMQ Technology Inc.                                     |                                       |                |
|-----------------------------------------------------------------------|---------------------------------------|----------------|
| No. : TDDS01-M6812-EN                                                 | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |
| T00MOD <dbe0><br/>Source clock<br/>Counter<br/>Write to T00REG</dbe0> |                                       |                |
| T00REG                                                                | n Match detection n-2                 |                |



| 7001400                 | Source clock (Hz)                              |                                                  |                   | Resol  | lution      | Maximum time setting |         |  |
|-------------------------|------------------------------------------------|--------------------------------------------------|-------------------|--------|-------------|----------------------|---------|--|
| T00MOD<br><tck0></tck0> | NORMAL 1/2 or<br>SYSCR1<br><dv9ck>="0"</dv9ck> | r IDLE 1/2 mode<br>SYSCR1<br><dv9ck>="1"</dv9ck> |                   |        | fcgck=16MHz | fs=32.768KHz         |         |  |
| 100                     | fcgck/2 <sup>4</sup>                           | fcgck/2 <sup>4</sup>                             | -                 | 1us    | -           | 1.0ms                |         |  |
| 101                     | fcgck/2 <sup>2</sup>                           | fcgck/2 <sup>2</sup>                             | -                 | 250ns  | -           | 255.8us              | -       |  |
| 110                     | fcgck/2                                        | fcgck/2                                          | -                 | 125ns  | _           | 127.9us              | -       |  |
| 111                     | fcgck                                          | fcgck                                            | fs/2 <sup>2</sup> | 62.5ns | 122.1us     | 63.9us               | 124.9ms |  |

Table 10.8 10-bit Timer Mode Resolution and Maximum Time Setting

## 10.5.3.2 10-bit Programmable Pulse Generate (PPG) Output Mode

In the 10-bit PPG mode, the pulses with arbitrary duty and cycle are output by using the TOOREGL/ TOOREGH and TOOPWML/ TOOPWMH registers.

By setting the T001CR <OUTAND> register, a pulse that is a logical ANDed product of the TCQ00 and TCQ01 outputs can be output to the TCQ01 pin. This function facilitates the generation of remote-controlled waveforms, for example.

The operation of TCQ00 is described below, and the same applies to the operation of TCQ01, and similarly, TCQ02~ TCQ05.

#### (a) Setting

TCQ00 is put into the 10-bit PPG mode by setting T00MOD <TCM0> to "1" and T001CR <TCAS> to"0". To use the internal clock as the source clock: Set T00MOD <EIN0> to "0" and select the clock at T00MOD <TCK0>. To use an external clock as the source clock, set T00MOD <EIN0> to "1". Set the duty pulse width at T00PWML/ T00PWMH and the cycle width at T00REG.

## Page: 148 / 278

Set T00MOD <DBE0> to "1" to use the double buffer.Only TCQ00,TCQ02,TCQ04 can use the double buffer.

Setting T001CR <T00RUN> to "1" starts the operation. After the timer is started, writing to T00MOD becomes invalid. Be sure to complete the required mode settings before starting the timer.



#### Figure 10.16 PPG00B Pulse Output

Note 1): PPG output is valid from 2<sup>nd</sup> period. The level cannot be set by register, please set the pin as I/O, after PPG is stop. (Detail please refer to appendix D) Note2): T00REG=T00REGH/L, T00PWM=T00PWMH/L

Set the initial state of the PPG0)B pin at T00MOD <TFF0>. Setting T00MOD <TFF0> to "0" selects the "L" level as the initial state of the PPG00B pin. Setting T00MOD <TFF0> to "1" selects the "H" level as the initial state of the PPG00B pin. If the PPG00B pin is set as the function output pin in the port setting while the timer is stopped, the value of T00MOD <TFF0> is output to the PPG00B pin.

Setting the T001CR <OUTAND> bit to "1" allows the PPG00B pin to output a pulse that is a logical ANDed product of the TCQ00 and TCQ01 outputs.

### (b) Operation

Setting T001CR <T00RUN> to "1" allows the up counter to increment based on the selected source clock. When a match between the internal up counter value and the value set to T00PWM is detected, the output of the PPG0B pin is reversed. When T00MOD <TFF0> is "0", the PPG00B pin changes from the "L" to "H" level. When T00MOD <TFF0> is "1", the PPG00B pin changes from the "L" to "L" level.

Subsequently, the up counter continues counting up. When a match between the up

## Page: 149/ 278

counter value and T00REG is detected, the output of the PPG0B pin is reversed again. When T00MOD <TFF0> is "0", the PPG0B pin changes from the "H" to "L" level. When T00MOD <TFF0> is "1", the PPG0B pin changes from the "L" to "H" level. At this time, an INTTC00 interrupt request is generated.

When T001CR <T00RUN> is set to "0" during the operation, the up counter is stopped and cleared to "0x00". The PPG00B pin returns to the level selected at T00MOD <TFF0>.

When the external source clock is selected, the maximum frequency to be supplied is fcgck/2 [Hz] (in NORMAL1/2 or IDLE1/2 mode) or  $fs/2^4$  [Hz] (in SLOW1/2 or SLEEP1 mode), and a pulse width of two machine cycles or more is required at both the "H" and "L" levels.

### (c) Double Buffer

The double buffer can be used for T00PWM and T00REG by setting T00MOD <DBE0>. The double buffer is disabled by setting T00MOD <DBE0> to "0" or enabled by setting T00MOD <DBE0> to "1". Only TCQ00,TCQ02,TCQ04 can use double buffer.

### 1. When the Double Buffer is Enabled

When a write instruction is executed on T00PWML/ T00PWMH(T00REGL/ T00REGH) during the timer operation, the set value is first stored in the double buffer, and T00PWML/ T00PWMH(T00REGL/ T00REGH) is not updated immediately. T00PWML/ T00PWMH(T00REGL/ T00REGH) compares the previous set value with the up counter value. When an INTTC00 interrupt request is generated, the double buffer set value is stored in T00PWML/T00PWMH(T00REGL/T00REGL/T00REGL/ T00REGL). Subsequently, the match detection is executed using a new set value.

When a read instruction is executed on T00PWML/T00PWMH(T00REGL/T00REGH), the value in the double buffer (the last set value) is read out, not the T00PWML/T00PWMH(T00REGL/T00REGH) value (the currently effective value).

When a write instruction is executed on T00PWML/T00PWMH(T00REGL/T00REGH) while the timer is stopped, the set value is immediately stored in both the double buffer and T00PWML/T00PWMH(T00REGL/T00REGH).

## 2. When the Double Buffer is Disabled

When a write instruction is executed on T00PWML/T00PWMH(T00REGL/T00REGH) during the timer operation, the set value is immediately stored in T00PWML/T00PWMH(T00REGL/T00REGH). Subsequently, the match detection is executed using a new set value.

If the value set to T00PWML/T00PWMH(T00REGL/T00REGH) is smaller than the up

## Page: 150 / 278

| 汉芝电子股份有限公司            |                                       |                |
|-----------------------|---------------------------------------|----------------|
| iMQ Technology Inc.   |                                       |                |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

counter value, the PPG00B pin is not reversed until the up counter overflows and a match detection is executed using a new set value(Figure 10.15). If the value set to T00PWML /T00PWMH (T00REGL/T00REGH) is equal to the up counter value, the match detection is executed immediately after data is written into T00PWML /T00PWMH (T00REGL /T00REGH). Therefore, the timing of changing the PPG00B pin may not be an integral multiple of the source clock (Figure 10.16). When use TCQ01, TCQ03, TCQ05, do not change the set value under operation(detail please refer to appendix D). Or enable double buffer by PPG00B, PPG02B ,PPG04B.

When a write instruction is executed on T00PWML /T00PWMH (T00REGL/T00REGH) while the timer is stopped, the set value is immediately stored in T00PWML /T00PWMH (T00REGL/T00REGH)



Note 1): Only TCQ00,TCQ02,TCQ04 can use double buffer. Note2): T00REG=T00REGH/L , T00PWM=T00PWMH/L

## Page: 151/ 278

|                                                  |                                                                          |                                        |                                  | . 11/20012/                                | 10100021/1                             | MQ6822 D                                      | สเสรา      |                                         | vci           | sion:V1.1                                |         |
|--------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------|----------------------------------|--------------------------------------------|----------------------------------------|-----------------------------------------------|------------|-----------------------------------------|---------------|------------------------------------------|---------|
| Change the set value v                           | 1,TCQ03,TCQ05, or TC<br>when PPG is operating<br>timing , it may cause a | , the set value wo                     | uld be effective im              | mediately.                                 |                                        |                                               |            |                                         |               |                                          |         |
| CR <toorun></toorun>                             |                                                                          |                                        |                                  |                                            |                                        |                                               |            |                                         |               |                                          |         |
| ter 0)                                           |                                                                          |                                        |                                  |                                            |                                        |                                               |            |                                         |               |                                          |         |
| to TOOPWM write m<br>WM                          |                                                                          | wri<br>S<br>wri                        |                                  |                                            |                                        |                                               |            |                                         |               |                                          |         |
| EG <u>p</u><br>pin output                        |                                                                          |                                        |                                  |                                            |                                        |                                               |            |                                         |               |                                          |         |
| No                                               | double buffer or do                                                      | ouble buffer dis                       | able (T00MOD                     | <dbe0>=0). Set 1</dbe0>                    | he new value v                         | when the set valu                             | ie(r) of   | this period is no                       | t over.       |                                          |         |
| ER <toorun></toorun>                             |                                                                          |                                        |                                  |                                            |                                        | en setting register a<br>int would count to i |            |                                         |               |                                          |         |
| 0D <tff0><br/>0D<d8e0><br/>e clock</d8e0></tff0> |                                                                          |                                        |                                  | ากการการา                                  |                                        |                                               |            |                                         |               |                                          | nn      |
| tor TOOPWM write m                               | ) <b>()</b> ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( (                          |                                        | ) m) m=1) <b>1</b> (p=1 ) (0 ( 1 |                                            |                                        | (r)(re1)( <b>1</b> )(m)(me1)( <b>1</b> )(b1)  |            | r (rel) (m (mel) (t)                    | xord <b>i</b> | (r)(r)( <b>1</b> )(m)(m2)( <b>1</b> )(b) | /@.j.2) |
| to TOOREG write p                                |                                                                          |                                        |                                  | wheet<br>t                                 |                                        |                                               |            |                                         |               |                                          |         |
| :00<br>                                          | <<<<< < >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>                                   | ۰۰۰۰ ۲۰۰۰ ۲۰۰۰ ۲۰۰۰ ۲۰۰۰ ۲۰۰۰ ۲۰۰۰ ۲۰۰ | ·>>>> ·····                      | ******                                     | p>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> |                                               | <<<< r >>> | <<<<< t >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | <             |                                          |         |
| No                                               | double buffer or do                                                      | ouble buffer dis                       | able (T00MOD                     | <dbe0>=0). Set 1</dbe0>                    | he new value v                         | vhen the set valu                             | ie(r) of   | this period is pa                       | ssed.         |                                          |         |
|                                                  |                                                                          | Note1): C                              | Only TCO00,                      | t PPG Mode<br>ICO02,TCO04<br>REGH/L , T00F | can use doul                           | ble buffer.                                   | )D<[       | DBE0>=″0″)                              |               |                                          |         |
|                                                  |                                                                          |                                        |                                  |                                            |                                        |                                               |            |                                         |               |                                          |         |

Figure 10.16 Operation When T00PWML/H (T00REGL/H) and the Up Counter Have the Same Value

### 10.5.3.3 10-bit Complementary Programmable Pulse Generate (PPG) Output Mode

n-3

Write n-2

Match detection

n-2

n-2

n-1

n

Counter

(TOOREG) TOOPWM

(TOOREG)

Write to T00PWM

PPG0 pin output

n-5

n

n-4

Note): TOOREG=TOOREGH/L, TOOPWM=TOOPWMH/L

In the 10-bit complementary PPG output mode, TCQ00 and TCQ01 would output the PPG complementary signals, the waveform are opposite and non-overlap. Output the timer 00 copmlemetary output from the PPG01B pins and the timer 00 output from the PPG00B pins.

## Page: 152/ 278

No. : TDDS01-M6812-EN

#### (a) Setting

TCQ00 and TCQ01 are put into the 10-bit PPG complementary output mode by setting T01CR <T00RUN> and <T01RUN> to"1".

Set T00MOD<TCM0> to "11" or "10" to select 10-bit PPG complementary output mode. To use the internal clock as the source clock: Set T00MOD <EIN0> to "0" and select the clock at T00MOD <TCK0>.

Note: In 10-bit PPG complementary output mode, the setting value is the same with T00MOD and T01MOD (x=0,1), except <TFFx>.

When a write instruction is executed on T00PWML/ T00PWMH(T00REGL/ T00REGH) during operation, the set value is first stored in the double buffer, and T00PWML/ T00PWMH(T00REGL/ T00REGH) is not updated immediately. T00PWML/ T00PWMH(T00REGL/ T00REGH) compares the previous set value with the up counter value. When an INTTC00 interrupt request is generated, the double buffer set value is stored in T00PWML/T00PWMH(T00REGL/T00REGL). Subsequently, the match detection is executed using a new set value.

Set the 10-bit counter value correspond to period by TOOREGL/TOOREGH. Set the 10-bit counter value correspond to operating pulse by TOOPWML/TOOPWMH. The 10-bit counter value from TOOREGL/H show as TOOREGL+H; The 10-bit counter value from TOOPWML/H show as TOOPWML+H. When write the set value to TOOPWMH, the set value would be correspond to double buffer or TOOREGL+H and TOOPWML+H. Set the value of TOOREGL/H and TOOPWML first, once write the set value to TOOPWMH, the setting of all registers would beome effective at the same time.

Set PPG00B initial status by T00MOD<TFF0>. Set T00MOD<TFF)> to "0", the initial statsu of PPG00B is Low.

Set the initial state of the PPG00B pin at T00MOD <TFF0>. Setting T00MOD <TFF0> to "0" selects the "L" level as the initial state of the PPG00B pin. Setting T00MOD <TFF0> to "1" selects the "H" level as the initial state of the PPG00B pin. In the same way, set the initial state of the PPG01B pin at T01MOD <TFF1>. Setting T01MOD <TFF1> to "0" selects the "L" level as the initial state of the PPG01B pin. Setting T01MOD <TFF1> to "1" selects the "H" level as the initial state of the PPG01B pin. Setting T01MOD <TFF1> to "1" selects the "H" level as the initial state of the PPG01B pin. Setting T01MOD <TFF1> to "1" selects the "H" level as the initial state of the PPG01B pin.

#### (b) Operation

Setting T001CR <T00RUN> to "1" allows the up counter to increment based on the selected source clock. When a match between the internal up counter value and the value set to T01PWML+H is detected, the output of the PPG01B pin is reversed. When T01MOD <TFF1>

## Page: 153/ 278

| 汉芝电子股份有限公司            |                                       |                |
|-----------------------|---------------------------------------|----------------|
| iMQ Technology Inc.   |                                       |                |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

is "0", the PPG01B pin changes from the "L" to "H" level. When T01MOD <TFF1> is "1", the PPG01B pin changes from the "H" to "L" level. At this time, an INTTC01 interrupt request is generated.

Subsequently, the up counter continues counting up. When a match between the up counter value and T01REGL+H is detected, the output of the PPG01B pin is reversed again. When T01MOD <TFF1> is "0", the PPG01B pin changes from the "H" to "L" level. When T00MOD <TFF1> is "1", the PPG01B pin changes from the "L" to "H" level. At this time, an INTTC01 interrupt request is generated.

When T001CR <T01RUN> is set to "0" during the operation, the up counter is stopped and cleared to "0x0000". The PPG01B pin returns to the level selected at T01MOD <TFF1>.



Figure 10.17 10-bit complementary PPG Mode Timing Chart(T00MOD<DBE0>="0")

### (c) Double Buffer

The double buffer can be used for T00PWML/H and T00REGL/H by setting T00MOD <DBE0>. The double buffer is disabled by setting T00MOD <DBE0> to "0" or enabled by setting T00MOD <DBE0> to "1". Only TCQ00,TCQ02,TCQ04 can use double buffer.

### 1. When the Double Buffer is Enabled

When a write instruction is executed on T00PWML/ T00PWMH first ,then excuted on (T00REGL/ T00REGH) during the timer operation, the set value is first stored in the double buffer, and T00PWML+H and T00REGL+H) is not updated immediately. T00PWML+H and T00REGL+H compares the previous set value with the up counter value. When an INTTC00 interrupt request is generated, the double buffer set value is

## Page: 154 / 278

| 汉芝电子股份有限公司            |                                       |                |   |
|-----------------------|---------------------------------------|----------------|---|
| iMQ Technology Inc.   |                                       |                | _ |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |   |

stored in T00PWML+H and T00REGL+H. Subsequently, the match detection is executed using a new set value.

When a read instruction is executed on T00PWML/T00PWMH first, then excuted on T00REGL/ T00REGH, the value in the double buffer (the last set value) is read out, not the T00PWML/T00PWMH(T00REGL/T00REGH) value (the currently effective value).

When a write instruction is executed on T00PWML/T00PWMH first, then excuted on T00REGL/ T00REGH, while the timer is stopped, the set value is immediately stored in both the double buffer, T00PWML+H and T00REGL+H. Only TCQ00,TCQ02,TCQ04 can use double buffer.

#### 2. When the Double Buffer is Disabled

When a write instruction is executed on T00PWML/T00PWMH first ,then executed on T00REGL/T00REGH during the timer operation, the set value is immediately stored in T00PWML+H and T00REGL+H. Subsequently, the match detection is executed using a new set value.

If the value set to T00PWML+H or T00REGL+H) is smaller than the up counter value, the PPG00B pin is not reversed until the up counter overflows and a match detection is executed using a new set value. If the value set to T00PWML+H or T00REGL+H is equal to the up counter value, the match detection is executed immediately after data is written into T00PWML+H and T00REGL+H. Therefore, the timing of changing the PPG00B pin may not be an integral multiple of the source clock. When use TCQ01, TCQ03, TCQ05, do not change the set value under operation(detail please refer to appendix D). Or enable double buffer by PPG00B, PPG02B, PPG04B.

When a write instruction is executed on TOOREGL, TOOREGH, and TOOPWML, then executed on TOOPWMH while the timer is stopped, the set value is immediately stored in TOOPWML+H and TOOREGL+TOOREGH.

## Page: 155 / 278

# 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1



Figure 10.18 10-bit complementary PPG Mode Timing Chart (T00MOD<DBE0>="1") Note1): Only TCO00,TCO02,TCO04 can use double buffer.

## Page: 156 / 278

No. : TDDS01-M6812-EN

# 10.6 16-bit Timer Counter (TCA)

MQ6812/MQ6821 contains 1 channels of high-performance 16-bit timer counters (TCA0).

This chapter describes the 16-bit timer counter TCA0.

|                  | TAxDAL<br>(Address) | TAxDRAH<br>(Address) | TAxDRBL<br>(Address) | TAxDRBH<br>(Address) | TAxMOD<br>(Address) | TAxCR<br>(Address) | TAxSR<br>(Address) | Low power<br>consumption<br>register |
|------------------|---------------------|----------------------|----------------------|----------------------|---------------------|--------------------|--------------------|--------------------------------------|
| Timer counter A0 | TA0DRAL             | TA0DRAH              | TA0DRBL              | TA0DRBH              | TA0MOD              | TA0CR              | TA0SR              | POFFCR0                              |
|                  | (0x002D)            | (0x002E)             | (0x002F)             | (0x0030)             | (0x0031)            | (0x0032)           | (0x0033)           | <tca0en></tca0en>                    |

#### Table 10.17 SFR Address Assignment

|                  | Timer Input Pin | PPG Output Pin |
|------------------|-----------------|----------------|
| Timer counter A0 | TCA0 pin        | PPGA0B pin     |

#### Table 10.18 Pin Names

### 10.6.1 Control

Timer Counter A0 is controlled by the low power consumption register (POFFCR0), the timer counter A0 mode register (TA0MOD), the timer counter A0 control register (TA0CR) and two 16-bit timer A0 registers (TA0DRA and TA0DRB).

| LOW FOWER           | consumpt | ion Registe |         |         |   |   |   |        |
|---------------------|----------|-------------|---------|---------|---|---|---|--------|
| POFFCR0<br>(0x0F74) | 7        | 6           | 5       | 4       | 3 | 2 | 1 | 0      |
| Bit Symbol          | -        | TC045EN     | TC023EN | TC001EN | - | - | - | TCA0EN |
| Read/Write          | R        | R/W         | R/W     | R/W     | R | R | R | R/W    |
| After reset         | 0        | 0           | 0       | 0       | 0 | 0 | 0 | 0      |

#### Low Power Consumption Register 0

| TC045EN | TC045 enable control | 0: Disable<br>1: Enable |
|---------|----------------------|-------------------------|
| TC023EN | TC023 enable control | 0: Disable<br>1: Enable |
| TC001EN | TC001 enable control | 0: Disable<br>1: Enable |
| TCA0EN  | TCA0 enable control  | 0: Disable<br>1: Enable |

Timer Counter A0 Mode Register

## Page: 157 / 278

# 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| TA0MOD<br>(0x0031) | 7      | 6      | 5                  | 4       | 3   | 2   | 1    | 0 |
|--------------------|--------|--------|--------------------|---------|-----|-----|------|---|
| Bit Symbol         | TA0DB1 | TA0TED | TA0MCAP<br>TA0METT | TA      | ОСК |     | ТАОМ |   |
| Read/Write         | R/W    | R/W    | R/W                | R/W R/W |     | R/W |      |   |
| After reset        | 1      | 0      | 0                  | 0       | 0   | 0   | 0    | 0 |

| TA0DBE   | Double buffer control                |                                                  | le the double bu<br>le the double buf         |                                             |                               |  |  |
|----------|--------------------------------------|--------------------------------------------------|-----------------------------------------------|---------------------------------------------|-------------------------------|--|--|
| TA0TED   | External trigger input selection     |                                                  | g edge / H Level<br>g edge / L Level          |                                             |                               |  |  |
| ТАОМСАР  | Pulse width measurement mode control | 0: Double edge capture<br>1: Single edge capture |                                               |                                             |                               |  |  |
| TAOMETT  | External trigger timer mode control  | 0: Trigger start<br>1: Trigger start and stop    |                                               |                                             |                               |  |  |
|          |                                      |                                                  | Normal 1/2, IE<br>SYSCR1<br><dv9ck>=0</dv9ck> | DLE 1/2 mode<br>SYSCR1<br><dv9ck>=1</dv9ck> | SLOW 1/2 mode<br>SLEEP 1 mode |  |  |
| ТАОСК    | Timer counter 1 source clock         | 00:                                              | fcgck/2 <sup>10</sup>                         | fs/2 <sup>3</sup>                           | fs/2 <sup>3</sup>             |  |  |
|          | selection                            | 01:                                              | fcgck/2 <sup>6</sup>                          | fcgck/2 <sup>6</sup>                        | -                             |  |  |
|          |                                      | 10:                                              | fcgck/2 <sup>2</sup>                          | fcgck/2 <sup>2</sup>                        | -                             |  |  |
|          |                                      | 11:                                              | fcgck/2                                       | fcgck/2                                     | -                             |  |  |
|          |                                      | 000:                                             | Timer mode                                    |                                             |                               |  |  |
|          |                                      | 001:                                             | Timer mode                                    |                                             |                               |  |  |
|          |                                      | 010:                                             | Event counter mode                            |                                             |                               |  |  |
| TAOM     | Timer counter 1 operation mode       | 011:                                             | PPG output mo                                 | de (Software sta                            | art)                          |  |  |
| 17 (0101 | selection                            | 100:                                             | External trigger                              | time mode                                   |                               |  |  |
|          |                                      | 101:                                             | Window mode                                   |                                             |                               |  |  |
|          |                                      | 110:                                             | Pulse width me                                | asurement mod                               | le                            |  |  |
|          |                                      | 111:                                             | Reserved                                      |                                             |                               |  |  |

Note 1): fcgck: Gear clock [Hz], fs: Low-frequency clock [Hz]

Note 2): Set TAOMOD in the stopped state (TAOCR <TAOS>="0"). Writing to TAOMOD is invalid during the operation (TAOCR <TA0S>="1"].

#### **Timer Counter A0 Control Register**

| TA0CR<br>(0x0032) | 7      | 6      | 5   | 4  | 3 | 2 | 1                  | 0    |
|-------------------|--------|--------|-----|----|---|---|--------------------|------|
| Bit Symbol        | TA0OVE | TA0TFF | TAC | NC | - | - | TA0ACAP<br>TA0MPPG | TAOS |
| Read/Write        | R/W    | R/W    | R/W |    | R | R | R/W                | R/W  |
| After reset       | 0      | 1      | 0   | 0  | 0 | 0 | 0                  | 0    |

| TA0OVE  | Overflow interrupt control                | <ul><li>0: Generate no INTTCA0 interrupt request when the counter overflow occurs.</li><li>1: Generate an INTTCA0 interrupt request when the counter overflow occurs.</li></ul> |                                |                               |  |  |
|---------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------------------|--|--|
| TA0TFF  | Timer F/F control                         | 0: Clear<br>1: Set                                                                                                                                                              |                                |                               |  |  |
| TA0MCAP | Pulse width measurement mode control      | 0: Double edge capture<br>1: Single edge capture                                                                                                                                |                                |                               |  |  |
| TA0NC   | Noise canceller sampling interval setting |                                                                                                                                                                                 | Normal 1/2 or IDLE 1/2<br>mode | SLOW 1/2 mode<br>SLEEP 1 mode |  |  |

## 汉芝电子股份有限公司 iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

|         |                               | 00:                                   | No noise canceller                        | No noise canceller |  |  |
|---------|-------------------------------|---------------------------------------|-------------------------------------------|--------------------|--|--|
|         |                               | 01:                                   | fcgck/2                                   | -                  |  |  |
|         |                               | 10:                                   | fcgck/2 <sup>2</sup>                      | -                  |  |  |
|         |                               | 11:                                   | fcgck/2 <sup>8</sup>                      | fs/2               |  |  |
| TA0ACAP | Auto capture function         |                                       | le the auto capture<br>e the auto capture |                    |  |  |
| TAOMPPG | PPG output control            | 0: Continuous<br>1: One-shot          |                                           |                    |  |  |
| TAOS    | Timer counter A start control | 0: Stop and counter clear<br>1: Start |                                           |                    |  |  |

Note 1/: The auto capture can be used only in the timer, event counter, external trigger timer and window modes.

Note 2): Set TAOTFF, TAOOVE and TAONC in the stopped state (TAOS="0"). Writing is invalid during the operation (TAOS="1"). Note 3): When the STOP mode is started, the start control (TAOS) is automatically cleared to "0" and the timer stops. Set TAOS again to use the timer counter after the release of the STOP mode.

Note 4]: When a read instruction is executed on TAOCR, bits 3 and 2 are read as "0".

Note 5]: Do not set TAONC to "01" or "10" when the SLOW 1/2 or SLEEP 1 mode is used. Setting TAONC to "01" or "10" stops the noise canceller and no signal is input to the timer.

#### **Timer Counter A0 Status Register**

| TA0SR<br>(0x0033) | 7      | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|-------------------|--------|---|---|---|---|---|---------|---------|
| Bit Symbol        | TA00VF | - | - | - | - | - | TA0CPFA | TA0CPFB |
| Read/Write        | R      | R | R | R | R | R | R       | R       |
| After reset       | 0      | 0 | 0 | 0 | 0 | 0 | 0       | 0       |

| TA0OVF  | Overflow flag             | 0: No overflow has occurred.<br>1: At least an overflow has occurred.                                                                                                                                                 |
|---------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TA0CPFA | Capture completion flag A | 0: No capture operation has been executed.<br>1: At least a pulse width capture has been executed in the double-<br>edge capture                                                                                      |
| TA0CPFB | Capture completion flag B | <ul> <li>Double edge capture</li> <li>At least a capture operation has been executed in the single-edge<br/>capture. At least a pulse duty width capture has been executed in the<br/>double-edge capture.</li> </ul> |

Note 1): TAOOVF, TAOCPFA and TAOCPFB are cleared to "0" automatically after TAOSR is read. Writing to TAOSR is invalid. Note 2]: When a read instruction is executed on TAOSR, bits 6 to 2 are read as "0".

#### Timer Counter A0 Register AH

| TA0DRAH<br>(0x002E) | 15  | 14      | 13  | 12  | 11  | 10  | 9   | 8   |  |  |  |
|---------------------|-----|---------|-----|-----|-----|-----|-----|-----|--|--|--|
| Bit Symbol          |     | TAODRAH |     |     |     |     |     |     |  |  |  |
| Read/Write          | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |
| After reset         | 1   | 1       | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |

## Timer Counter A0 Reaister AL

| Timer Court         |   |   |   |   |   |   |   |   |  |  |  |  |
|---------------------|---|---|---|---|---|---|---|---|--|--|--|--|
| TA0DRAL<br>(0x002D) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |

# 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Bit Symbol  |     | TAODRAL |     |     |     |     |     |     |  |  |
|-------------|-----|---------|-----|-----|-----|-----|-----|-----|--|--|
| Read/Write  | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |  |
| After reset | 1   | 1       | 1   | 1   | 1   | 1   | 1   | 1   |  |  |

#### Timer Counter A0 Register BH

| TA0DRBH<br>(0x0030) | 15  | 14      | 13  | 12  | 11  | 10  | 9   | 8   |  |  |  |
|---------------------|-----|---------|-----|-----|-----|-----|-----|-----|--|--|--|
| Bit Symbol          |     | TAODRBH |     |     |     |     |     |     |  |  |  |
| Read/Write          | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |
| After reset         | 1   | 1       | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |

#### Timer Counter A0 Register BL

| TAODRBL<br>(0x002F) | 7   | 6       | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|---------------------|-----|---------|-----|-----|-----|-----|-----|-----|--|--|--|
| Bit Symbol          |     | TAODRBL |     |     |     |     |     |     |  |  |  |
| Read/Write          | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |
| After reset         | 1   | 1       | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |

Note 1): When a write instruction is executed on TAODRAL (TAODRBL), the set value does not become effective immediately, but is temporarily stored in the temporary buffer. Subsequently, when a write instruction is executed on the higher-level register, TAODRAH (TAODRBH), the 16-bit set values are collectively stored in the double buffer or TAODRAL/H. When setting data to the timer counter A0 register, be sure to write the data into the lower level register and the higher level in this order. Note 2): The timer counter A0 register is not writable in the pulse width measurement mode.

## 10.6.2 Low Power Consumption Function

Timer counter A0 has the low power consumption register (POFFCR0) that saves power consumption when the timer is not used.

Setting POFFCR0<TCA0EN> to "0" disables the basic clock supply to timer counter A0 to save power. Note that this makes the timer unusable. Setting POFFCR0<TCA0EN> to "1" enables the basic clock supply to timer counter A0 and allows the timer to operate.

After reset, POFFCR0<TCA0EN> is initialized to "0", and this makes the timer unusable. When using the timer for the first time, be sure to set POFFCR0<TCA0EN> to "1" in the initial setting of the program (before the timer control register is operated).

Do not change POFFCR0<TCA0EN> to "0" during the timer operation. Otherwise timer counter A0 may operate unexpectedly.

## 10.6.3 Timer Function

Timer counter A0 has six types of operation modes; timer, external trigger timer, event counter,

## Page: 160 / 278

window, pulse width measurement and programmable pulse generate (PPG) output modes.

## 10.6.3.1 Timer Mode

In the timer mode, the up-counter counts up using the internal clock, and interrupts can be generated regularly at specified times.

### (a) Setting

Setting the operation mode selection TA0MOD <TA0M> to "000" or "001" activates the timer mode. Select the source clock at TA0MOD <TA0CK>.

Setting TAOCR <TAOS> to "1" starts the timer operation. After the timer is started, writing to TAOMOD and TAOCR <TAOOVE> becomes invalid. Be sure to complete the required mode settings before starting the timer.

|                 |                                  | Source clock [Hz]                |                           | Reso        | lution       | Maximum time setting |              |
|-----------------|----------------------------------|----------------------------------|---------------------------|-------------|--------------|----------------------|--------------|
| TA0MOD          | NORMAL 1/2 or                    | IDLE 1/2 mode                    |                           |             |              |                      |              |
| <ta0ck></ta0ck> | SYSCR1 <dv9ck><br/>= "0"</dv9ck> | SYSCR1 <dv9ck><br/>= "1"</dv9ck> | SLOW1/2 or<br>SLEEP1 mode | fcgck=10MHz | fs=32.768kHz | fcgck=10MHz          | fs=32.768kHz |
| 00              | fcgck/2 <sup>10</sup>            | fs/2 <sup>3</sup>                | fs/2 <sup>3</sup>         | 102.4µs     | 244.1µs      | 6.7s                 | 16s          |
| 01              | fcgck/2 <sup>6</sup>             | fcgck/2 <sup>6</sup>             | -                         | 6.4µs       | -            | 419.4ms              | -            |
| 10              | fcgck/2 <sup>2</sup>             | fcgck/2 <sup>2</sup>             | -                         | 400ns       | -            | 26.2ms               | -            |
| 11              | fcgck/2                          | fcgck/2                          | -                         | 200ns       | -            | 13.1ms               | -            |

Table 10.11 Timer Mode Resolution and Maximum Time Setting

### (b) Operation

Setting TA0CR <TA0S> to "1" allows the 16-bit up counter to increment based on the selected internal source clock. When a match between the up-counter value and the value set to timer register A (TA0DRA) is detected, an INTTCA0 interrupt request is generated and the up counter is cleared to "0x0000". After being cleared, the up counter continues counting. Setting TA0CR <TA0S> to "0" during the timer operation causes the up counter to stop counting and be cleared to "0x0000".

## (c) Auto Capture

The latest contents of the up counter can be taken into timer register B (TA0DRB) by setting TA0CR <TA0ACAP> to "1" (auto capture function). When TA0CR<TA0ACAP> is "1", the current contents of the up counter can be read by reading TA0DRBL. TA0DRBH is loaded at the same time as TA0DRBL is read. Therefore, when reading the captured value, be sure to read TA0DRBL and TA0DRBH in this order. (The capture time is the timing when TA0DRBL is read.) The auto capture function can be used whether the timer is operating or stopped. When the timer is stopped, TA0DRBL is read as "0x00". TA0DRBH keeps the captured value after the timer stops, but it is cleared to "0x00" when TA0DRBL is read while the timer is stopped.

## Page: 161/ 278

If the timer is started with TAOCR <TA0ACAP> written to "1", the auto capture is enabled immediately after the timer is started.

Note): The value set to TAOCR <TAOACAP> cannot be changed at the same time as TAOCR <TAOS> is rewritten from "1" to "0". (This setting is invalid.)

#### (d) Register Buffer Configuration

### 1. Temporary Buffer

MQ6812/MQ6821 contains an 8-bit temporary buffer. When a write instruction is executed on TA0DRAL, the data is first stored into this temporary buffer, whether the double buffer is enabled or disabled. Subsequently, when a write instruction is executed on TA0DRAH, the set value is stored into the double buffer or TA0DRAH. At the same time, the set value in the temporary bufferis stored into the double buffer or TA0DRAH. At the same time, the set value is designed to enable the set values of the lower-level and higher-level registers simultaneously.) Therefore, when setting data to TA0DRA, be sure to write the data into TA0DRAL and TA0DRAH in this order.

### 2. Double Buffer

In the MQ6812/MQ6821, the double buffer can be used by setting TA0MOD <TA0DBE>. Setting TA0CR TA0MOD <TA0DBE> to "0" disables the double buffer. Setting TA0MOD <TA0DBE> to "1" enables the double buffer.

## 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

| ↓ Timer start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Timer stop                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| TA0CR <ta0s></ta0s>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                |
| TA0MOD <ta0dbe></ta0dbe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | บุโบบบ                         |
| Counter 0 1 2 3 4 mn-1 0 1 2 3 million 1 2 3 | 1 2 0<br>Counter clear         |
| Write to TA0DRAL Write n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Counter cicar                  |
| Write to TA0DRAH Write m Write r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |
| Temporary buffer X n X s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |
| TAODRAL (n ) s o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |
| Match detection Match detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |
| TAODRAH (m c ) r c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                |
| INTTCA0 interrupt request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                |
| Reflected by w<br>When the double buffer is disabled (TA0MOD <ta0dbe>="0")</ta0dbe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | riting to TA0DRAH              |
| Timer start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| TAOCR <taos></taos>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                |
| TA0MOD <ta0dbe></ta0dbe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |
| Counter 0 1 2 3 4 /// // // 0 1 2 3 /// /////////////////////////////                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                |
| Write to TA0DRAL Write n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |
| Write to TA0DRAH Write m Write r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |
| Temporary buffer / n / s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |
| Double buffer (16 bits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                |
| Match detection Match detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Match detection                |
| TAODRAH (m o) r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Ŷ                              |
| INTTCA0 interrupt request<br>the timer is stopped                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | flected by $\psi$<br>interrupt |
| When the double buffer is enabled (TA0MOD <ta0dbe>="1")</ta0dbe>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                |

Figure 10.19 Timer Mode Timing Chart

No. : TDDS01-M6812-EN

## - When the double buffer is enabled

When a write instruction is executed on TA0DRAH during the timer operation, the set value is first stored into the double buffer, and TA0DRAH/L are not updated immediately. TA0DRAH/L compare the up counter value to the last set values. If the values are matched, an INTTCA0 interrupt request is generated and the double buffer set value is stored in TA0DRAH/L. Subsequently, the match detection is executed using a new set value.

When a read instruction is executed on TA0DRAH/L, the double buffer value (the last set value) is read, rather than the TA0DRAH/L values (the current effective values).

When a write instruction is executed on TA0DRAH/L while the timer is stopped, the set value is immediately stored into both the double buffer and TA0DRAH/L.

## - When the double buffer is disabled

When a write instruction is executed on TA0DRAH during the timer operation, the set value is immediately stored into TA0DRAH/L. Subsequently, the match detection is executed using a new set value.

If the values set to TAODRAH/L are smaller than the up counter value, the match detection is executed using a new set value after the up counter overflows. Therefore, the interrupt request interval may be longer than the selected time. If that is a problem, enable the double buffer.

When a write instruction is executed on TA0DRAH/L while the timer is stopped, the set value is immediately stored into TA0DRAH/L.



Page: 164 / 278

## Figure 10.20 Timer Mode Timing Chart (Auto Capture)

## 10.6.3.2 External Trigger Timer Mode

In the external trigger timer mode, the up counter starts counting when it is triggered by the input to the TCA0 pin.



#### (a) Setting

Setting the operation mode selection TA0MOD <TA0M> to "100" activates the external trigger timer mode. Select the source clock at TA0MOD <TA0CK>.

Select the trigger edge at the trigger edge input selection TA0MOD <TA0TED>. Setting TA0MOD <TA0TED> to "0" selects the rising edge, and setting it to "1" selects the falling edge.

Note that this mode uses the TCA0 input pin, and the TCA0 pin must be set to the input mode beforehand in port settings.

The operation is started by setting TAOCR <TAOS> to "1". After the timer is started, writing to TAOMOD and TAOCR <TAOOVE> is disabled. Be sure to complete the required mode settings before starting the timer.

#### (b) Operation

After the timer is started, when the selected trigger edge is input to the TCA0 pin, the up counter increments according to the selected source clock. When a match between the up counter value and the value set to timer register A (TA0DRA) is detected, an INTTCA0 interrupt request is generated and the up counter is cleared to "0x0000". After being cleared, the up counter continues counting.

When TA0MOD <TA0METT> is "1" and the edge opposite to the selected trigger edge is detected, the up counter stops counting and is cleared to "0x0000". Subsequently, when the selected trigger edge is detected, the up counter restarts counting. In this mode, an interrupt request can be generated by detecting that the input pulse exceeds a certain pulse width. If TA0MOD <TA0METT> is "0", the detection of the selected edge and the opposite edge is ignored during the period from the detection of the specified trigger edge and the start of counting through until the match detection.

Setting TAOCR <TAOS> to "0" during the timer operation causes the up counter to stop counting and be cleared to "0x0000".

#### (c) Auto Capture

Refer to "10.3.3.1 (c) Auto Capture".

(d) Register Buffer Configuration

Refer to "10.3.3.1 (d) Register Buffer Configuration ".

### 10.6.3.3 Event Counter Mode

In the event counter mode, the up counter counts up at the edge of the input to the TCA0 pin.

## Page: 166 / 278

No. : TDDS01-M6812-EN

Name : MO6812/MO6821/MO6822 Datasheet

#### (a) Setting

Setting the operation mode selection TA0MOD <TA0M> to "010" activates the event counter mode.

Set the trigger edge at the external trigger input selection TA0MOD <TA0TED>. Setting TA0MOD <TA0TED> to "0" selects the rising edge, and setting it to "1" selects the falling edge for counting up.

Note that this mode uses the TCA0 input pin, and the TCA0 pin must be set to the input mode beforehand in port settings.

The operation is started by setting TAOCR <TAOS> to "1". After the timer is started, writing to TAOMOD and TAOCR <TAOOVE> is disabled. Be sure to complete the required mode settings before starting the timer.

#### (b) Operation

After the event counter mode is started, when the selected trigger edge is input to the TCA0 pin, the up counter increments.

When a match between the up counter value and the value set to timer register A (TA0DRA) is detected, an INTTCA0 interrupt request is generated and the up counter is cleared to "0x0000". After being cleared, the up counter continues counting and counts up at each edge of the input to the TCA0 pin. Setting TA0CR <TA0S> to "0" during the operation causes the up counter to stop counting and be cleared to "0x0000".

The maximum frequency to be supplied is  $fcgck/2^2$  [Hz] (in the NORMAL 1/2 or IDLE 1/2 mode) or fs/  $2^4$  [Hz] (in the SLOW 1/2 or SLEEP 1 mode), and a pulse width of two machine cycles or more is required at both the "H" and "L" levels.

### (c) Auto Capture

Refer to "10.3.3.1 (c) Auto Capture".

### (d) Register Buffer Configuration

Refer to "10.3.3.1 (d) Register Buffer Configuration ".

## Page: 167 / 278

# 汉芝电子股份有限公司

iMQ Technology Inc. No. : TDDs01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet





When the rising edge is selected (TA0MOD<TA0TED>="0")

#### Figure 10.22 Event Counter Mode Timing Chart

#### 10.6.3.4 Window Mode

In the window mode, the up counter counts up at the rising edge of the pulse that is logical anded product of the input pulse to the TCA0 pin (window pulse) and the internal clock.

(a) Setting

Setting the operation mode selection TA0MOD <TA0M> to "101" activates the window mode. Select the source clock at TA0MOD <TA0CK>.

Select the window pulse level at the trigger edge input selection TA0MOD <TA0TED>. Setting TA0MOD <TA0TED> to "0" enables counting up as long as the window pulse is at the "H" level. Setting TA0MOD <TA0TED> to "1" enables counting up as long as the window pulse is at the "L" level.

Note that this mode uses the TCA0 input pin, and the TCA0 pin must be set to the input mode beforehand in port settings.

The operation is started by setting TA01CR <TA0S> to "1". After the timer is started, writing to TA0MOD and TA0CR <TA0OVE> is disabled. Be sure to complete the required mode settings before starting the timer.

### (b) Operation

After the operation is started, when the level selected at TA0MOD <TA0TED> is input to the TCA0 pin, the up counter increments according to the source clock selected at TA0MOD <TA0CK>. When a match between the up counter value and the value set to timer register A (TA0DRA) is detected, an INTTCA0 interrupt request is generated and the up counter is

## Page: 168 / 278

cleared to "0x0000". After being cleared, the up counter restarts counting.

The maximum frequency to be supplied must be slow enough for the program to analyze the count value. Define a frequency pulse that is sufficiently lower than the programmed internal source clock.

Setting TAOCR <TAOS> to "0" during the timer operation causes the up counter to stop counting and be cleared to "0x0000".

|                          | ↓ Timer start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Timer stop |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| TA0CR <ta0s></ta0s>      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |
|                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |
| TA0MOD <ta0ted></ta0ted> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |
|                          | Count in the period of H level Count in the period of H level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            |
| TCA0 pin input           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |
| Source clock             | [1,1,1,1,1,1], [1,1,1], [1,1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1,1], [1,1], [1,1], [1,1], [1,1], [1,1], [1,1], [1,1], [1,1], |            |
| Counter                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | X 0        |
| Write to TA0DRAL         | Write n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |
| Write to TA0DRAH         | Write m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |
| TAODRAL                  | (n o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |
|                          | Match detection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |
| TAODRAH                  | <u> </u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |
|                          | <b>↓</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |
| INTTCA0 interrupt re     | equest Seflected by writing to TAODRAH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |            |

During the H-level counting (TA0MOD<TA0TED>="0") Figure 10.23 Window Mode Timing Chart

#### (c) Auto Capture

Refer to "10.3.3.1 (c) Auto Capture".

### (d) Register Buffer Configuration

Refer to "10.3.3.1 (d) Register Buffer Configuration ".

### 10.6.3.5 Pulse Width Measurement Mode

In the pulse width measurement mode, the up counter starts counting at the rising/falling edge(s) of the input to the TCA0 pin and measures the input pulse width based on the internal clock.

### (a) Setting

Setting the operation mode selection TA0MOD <TA0M> to "110" activates the pulse width measurement mode. Select the source clock at TA0MOD <TA0CK>.

## Page: 169 / 278

| 汉芝电子股份有限公司            |                                       |                |
|-----------------------|---------------------------------------|----------------|
| iMQ Technology Inc.   |                                       |                |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

Select the trigger edge at the trigger edge input selection TA0MOD <TA0TED>. Setting TA0MOD <TA0TED> to "0" selects the rising edge, and setting it to "1" selects the falling edge as a trigger to start the capture.

The operation after capturing is determined by the pulse width measurement mode control TA0MOD <TA0MCAP>. Setting TA0MOD <TA0MCAP> to "0" selects the double-edge capture. Setting TA0MOD <TA0MCAP> to "1" selects the single-edge capture.

The operation to be executed in case of an overflow of the up counter can be selected at the overflow interrupt control TAOCR <TAOOVE>. Setting TAOOVE to "1" makes an INTTCA0 interrupt request occur in case of an overflow. Setting TAOOVE to "0" makes no INTTCA0 interrupt request occur in case of an overflow.

Note that this mode uses the TCA0 input pin, and the TCA0 pin must be set to the input mode beforehand in port settings.

The operation is started by setting TA01CR <TA0S> to "1". In this time, TA0DRA and TA0DRB register are initialized to "0x0000". After the timer is started, writing to TA0MOD and TA0CR <TA0OVE> is disabled. Be sure to complete the required mode settings before starting the timer.

### (b) Operation

After the timer is started, when the selected trigger edge (start edge) is input to the TCA0 pin, INTTCA0 interrupt request is generated, and then the up counter increments according to the selected source clock. Subsequently, when the edge opposite to the selected edge is detected, the up counter value is captured into TA0DRB, an INTTCA0 interrupt request is generated, and TA0SR <TA0CPFB> is set to "1". Depending on the TA0MOD <TA0MCAP> setting, the operation differs as follows:

### 1. Double-edge capture (When TA0MOD <TA0MCAP> is "0")

The up counter continues counting up after the edge opposite to the selected edge is detected. Subsequently, when the selected trigger edge is input, the up counter value is captured into TA0DRA, an INTTCA0 interrupt request is generated, and TA0SR <TA0CPFA> is set to "1". At this time, the up counter is cleared to "0x0000".

## 2. Single-edge capture (When TA0MOD <TA0MCAP> is "1")

The up counter stops counting up and is cleared to "0x0000" when the edge opposite to the selected edge is detected. Subsequently, when the start edge is input, INTTCA0 interrupt request is generated, and then the up counter restarts increment.

When the up counter overflows during capturing, the overflow flag TA0SR <TA0OVF> is set to "1". At this time, an INTTCA0 interrupt request occurs if the overflow interrupt control TA0CR <TA0OVE> is set to "1".

## Page: 170 / 278

The capture completion flags (TA0SR <TA0CPFA, TA0CPFB> and the overflow flag (TA0SR <TA0OVF>) are cleared to "0" automatically when TA0SR is read.

The captured value must be read from TA0DRB (and also from TA0DRA for the double-edge capture) before the next trigger edge is detected. If the captured value is not read, it becomes undefined. TA0DRA and TA0DRB must be read by using a 16-bit access instruction.

Setting TAOCR <TAOS> to "0" during the timer operation causes the up counter to stop counting and be cleared to "0x0000".

| Timer start                                                                                                                                                                                                                                                                                                     | ▼ Timer stop              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| TAOCR <taos></taos>                                                                                                                                                                                                                                                                                             |                           |
| TA0MOD <ta0ted></ta0ted>                                                                                                                                                                                                                                                                                        |                           |
| TCA0 pin input                                                                                                                                                                                                                                                                                                  |                           |
|                                                                                                                                                                                                                                                                                                                 | าบบบ                      |
| Counter 0 1 2 3 4 0 mn-1 0 Counter clear                                                                                                                                                                                                                                                                        | 3 0<br>Counter clear      |
| TAODRBH, L X 0 Xmn TAODRD and                                                                                                                                                                                                                                                                                   |                           |
| TA0SR <ta0cpfb></ta0cpfb>                                                                                                                                                                                                                                                                                       |                           |
| INTTCA0 interrupt request                                                                                                                                                                                                                                                                                       | read                      |
| After the timer is started, if the falling edge<br>is detected first, no interrupt occurs. Single-edge capture (TA0MOD <ta0mcap>="1")</ta0mcap>                                                                                                                                                                 |                           |
| Timer start                                                                                                                                                                                                                                                                                                     | ▼ Timer stop              |
| TAOCR <taos></taos>                                                                                                                                                                                                                                                                                             |                           |
| TAOMOD <taoted></taoted>                                                                                                                                                                                                                                                                                        |                           |
| TCA0 pin input                                                                                                                                                                                                                                                                                                  |                           |
|                                                                                                                                                                                                                                                                                                                 | บบบบ                      |
| Counter $0 \sqrt{1} \sqrt{2} \sqrt{3} \sqrt{4} \sqrt{2} \sqrt{mn-1} \sqrt{mn} \sqrt{mn+1} \sqrt{3} \sqrt{st-1} \sqrt{0} \sqrt{1} \sqrt{2} \sqrt{mn-1} \sqrt{mn} \sqrt{mn+1} \sqrt{3} \sqrt{st-1} \sqrt{0} \sqrt{1} \sqrt{2} \sqrt{3} \sqrt{1} \sqrt{3} \sqrt{3} \sqrt{3} \sqrt{3} \sqrt{3} \sqrt{3} \sqrt{3} 3$ | 2 0<br>lear Counter clear |
| TA0DRBH, L X 0 Xmn ♦ TA0DRB read                                                                                                                                                                                                                                                                                |                           |
| TAODRAH, L 0 st o                                                                                                                                                                                                                                                                                               |                           |
| TAOSR <taocpfb></taocpfb>                                                                                                                                                                                                                                                                                       | 0DRA read                 |
| TAOSR <taocpfa></taocpfa>                                                                                                                                                                                                                                                                                       |                           |
| INTTCA0 interrupt request                                                                                                                                                                                                                                                                                       | ead                       |
| After the timer is started, if the falling edge<br>is detected first, no interrupt occurs. Double-edge capture (TA0MOD <ta0mcap>="0")</ta0mcap>                                                                                                                                                                 |                           |

#### Figure 10.24 Pulse Width Measurement Mode Timing Chart

Note): After the timer is started, if the edge opposite to the selected trigger edge is detected first, no capture is executed and no INTTCA0 interrupt request occurs. In this case, the capture starts when the selected trigger edge

Page: 171/ 278

is detected next.

#### (c) Capture Process

Figure 10.23 shows an example of the capture process for INTTCA0 interrupt subroutine. The capture edge or overflow state can be easily judged by status register (TA0SR).



Interrupt process for single-edge capture

Interrupt process for double-edge capture



#### 10.6.3.6 Programmable pulse generate (PPG) mode

In the PPG output mode, an arbitrary duty pulse is output by two timer registers.

(a) Setting

Setting the operation mode selection TA0MOD <TA0M> to "011" activates the PPG output mode. Select the source clock at TA0MOD <TA0CK>. Select continuous or one-shot PPG output at TA0CR <TA0MPPG>.

Set the PPG output cycle at TA0DRA and set the time until the output is reversed first at TA0DRB. Be sure to set register values so that TA0DRA is larger than TA0DRB. Note that this mode uses the PPGA0B pin. The PPGA0B pin must be set to the output mode beforehand in port settings.

Set the initial state of the PPGA0B pin at the timer flip-flop TA0CR <TA0TFF>. Setting TA0CR

## Page: 172 / 278

<TAOTFF> to "1" selects the "H" level as the initial state of the PPGA0B pin. Setting TAOCR <TAOTFF> to "0" selects the "L" level as the initial state of the PPGA0B pin.

The operation is started by setting TA0CR<TA0S> to "1". After the timer is started, writing to TA0MOD and TA0CR <TA0OVE, TA0TFF> is disabled. Be sure to complete the required mode settings before starting the timer.

### (b) Operation

After the timer is started, the up counter increments.

When a match between the up counter value and the value set to timer register B (TA0DRB) is detected, the PPGA0B pin is changed to the "H" level if TA0CR <TA0TFF> is "0", or the PPGA0B pin is changed to the "L" level if TA0CR <TA0TFF> is "1".

Subsequently, the up counter continues counting. When a match between the up counter value and the value set to timer register A (TAODRA) is detected, the PPGA0B pin is changed to the "L" level if TAOCR <TAOTEFF> is "0", or the PPGA0B pin is changed to the "H" level if TAOCR <TAOTFF> is "1". At this time, an INTTCA0 interrupt request occurs. If the PPG output control TAOCR <TAOMPPG> is set to "1" (one-shot), TAOCR <TAOS> is automatically cleared to "0" and the timer stops.

If TAOCR <TAOMPPG> is set to "0" (continuous), the up counter is cleared to "0x0000" and continues counting and PPG output. When TAOCR <TAOS> is set to "0" (including the auto stop by the one-shot operation) during the PPG output, the PPGAOB pin returns to the level set in TAOCR<TAOTFF>.

TAOCR <TAOMPPG> can be changed during the operation. Changing TAOCR <TAOMPPG> from "1" to "0" during the operation cancels the one-shot operation and enables the continuous operation. Changing TAOCR<TAOMPPG> from "0" to "1" during the operation clears TAOCR<TAOS> to "0" and stops the timer automatically after the current pulse output is completed.

Timer registers A and B can be set to the double buffer. Setting TA0CR <TA0DBF> to "1" enables the double buffer. When the values set to TA0DRA and TA0DRB are changed during the PPG output with the double buffer enabled, the writing to TA0DRA and TA0DRB will not immediately become effective but will become effective when a match between TA0DRA and TA0DRB will become effective immediately. If the written value is smaller than the up counter value, the up counter overflows. After a cycle, the counter match process is executed to reverse the output.

- (c) Register Buffer Configuration
  - 1. Temporary Buffer

## Page: 173/ 278

| 汉芝电子股份有限公司            |                                       |                |
|-----------------------|---------------------------------------|----------------|
| iMQ Technology Inc.   |                                       |                |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

MQ6812/MQ6821 contains an 8-bit temporary buffer. When a write instruction is executed on TA0DRAL (TA0DRBL), the data is first stored into this temporary buffer, whether the double buffer is enabled or disabled. Subsequently, when a write instruction is executed on TA0DRAH (TA0DRBH), the set value is stored into the double buffer or TA0DRAH (TA0DRBH). At the same time, the set value in the temporary buffer is stored into the double buffer or TA0DRAL (TA0DRBH). (This structure is designed to enable the set values of the lower-level register and the higher-level register simultaneously.) Therefore, when setting data to TA0DRA (TA0DRB), be sure to write the data into TA0DRAL and TA0DRAH (TA0DRBL and TA0DRBH) in this order.

#### 2. Double Buffer

In MQ6812/MQ6821, the double buffer can be used by setting TA0CR <TA0DBF>. Setting TA0CR <TA0DBF> to "0" disables the double buffer. Setting TA0CR <TA0DBF> to "1" enables the double buffer.

#### - When the double buffer is enabled

When a write instruction is executed on TAODRAH (TAODRBH) during the timer operation, the set value is first stored into the double buffer, and TAODRAH/L are not updated immediately. TAODRAH/L (TAODRBH/L) compare the last set values to the counter value.

If a match is detected, an INTTCA0 interrupt request is generated and the double buffer set value is stored into TA0DRAH/L (TA0DRBH/L). Subsequently, the match detection is executed using a new set value.

When a read instruction is executed on TA0DRAH/L (TA0DRBH/L), the double buffervalue (the last set value) is read, not the TA0DRAH/L (TA0DRBH/L) values (the current effectivevalues).

When a write instruction is executed on TA0DRAH/L (TA0DRBH/L) while the timer is stopped, the set value is immediately stored into both the double buffer and TA0DRAH/L (TA0DRBH/L).

### - When the double buffer is disabled

When a write instruction is executed on TAODRAH (TAODRBH) during the timer operation, the set value is immediately stored in TAODRAH/L (TAODRBH/L). Subsequently, the match detection is executed using a new set value.

If the values set to TA0DRAH/L (TA0DRBH/L) are smaller than the up counter value, the up counter overflows and the match detection is executed using a new set value. As a result, the output pulse width may be longer than the set time. If that is a problem, enable the double buffer.

## Page: 174 / 278

When a write instruction is executed on TA0DRAH/L (TA0DRBH/L) while the timer is stopped, the set value is immediately stored into TA0DRAH/L (TA0DRBH/L).







No. : TDDS01-M6812-EN

### 10.6.4 Noise Canceller

The digital noise canceller can be used in the operation modes that use the TCA0 pin.

When the digital noise canceller is used, the input level is sampled at the sampling intervals set at TAOCR <TAONC>. When the same level is detected three times consecutively, the level of the input to the timer is changed.

Setting TAOCR <TAONC> to any values than "00" allows the noise canceller to start operation, regardless of the TAOCR <TAOS> value.

When the noise canceller is used, allow the timer to start after a period of time that is equal to four times the sampling interval after TAOCR <TAONC> is set has elapsed. This stabilizes the input signal. Set TAOCR <TAONC> while the timer is stopped (TAOCR <TAOS> = "0"). When TAOCR <TAOS> is "1", writing is ignored.

In the SLOW 1/2 or SLEEP 1 mode, setting TA0CR <TA0NC> to "11" selects fs/2 as the source clock for the operation. Setting TA0CR <TA0NC> to "00" disables the noise canceller. Setting TA0CR <TA0NC> to "01" or "10" disables the TCA0 pin input.

## Page: 176 / 278

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 11. LCD

The LCD driver of can directly drive a LCD glass by creating th ac segment and common voltage signals. The LCD related pins :

- 1. Segment (SEG11 to SEG0): 12 pins
- 2. Common( COM7 to COM0) : 8pins

The LCD driver can support 8 types LCD device:

1. 1/8 duty (1/4 bias) LCD · maximum 96 pixels
 2. 1/8 duty (1/3 bias) LCD · maximum 96 pixels
 3. 1/8 duty (1/2 bias) LCD · maximum 96 pixels
 4. 1/4 duty (1/3 bias) LCD · maximum 48 pixels
 5. 1/3 duty (1/3 bias) LCD · maximum 36 pixels
 6. 1/3 duty (1/2 bias) LCD · maximum 36 pixels
 7. 1/2 duty (1/2 bias) LCD · maximum 24 pixels
 8. Static LCD · maximum 12 pixels.

Note : The VDD sohlud be same as voltage of LCD.



# 11.1 Configuration



Page: 177 / 278

# 11.2 Control

LCD consists of the following six registers: low power consumption register (POFFCR2) \ LCD control register1(LCDCR1) \ LCD control register 2 (LCDCR2) \ LCD control register 3 (LCDCR3) \ LCD control register 4 (LCDCR4) and LCD control register 5 (LCDCR5).

| POFFCR2<br>(0x0F76) | 7     | 6 | 5     | 4 | 3 | 2 | 1 | 0      |  |
|---------------------|-------|---|-------|---|---|---|---|--------|--|
| Bit Symbol          | LCDEN | - | RTCEN | - | - | - | - | SIO0EN |  |
| Read/Write          | R/W   | R | R/W   | R | R | R | R | R/W    |  |
| After reset         | 0     | 0 | 0     | 0 | 0 | 0 | 0 | 0      |  |

#### Low power consumption register 2

| LCDEN  | LCD control  | 0: Disable<br>1: Enable |
|--------|--------------|-------------------------|
| RTCEN  | RTC control  | 0: Disable<br>1: Enable |
| SIO0EN | SIO0 control | 0: Disable<br>1: Enable |

#### LCD control register1

| LCDCR1<br>(0x0E7C) | 7    | 6   | 5    | 4   | 3   | 2   | 1   | 0   |
|--------------------|------|-----|------|-----|-----|-----|-----|-----|
| Bit Symbol         | EDSP |     | DUTY |     | SLF |     |     |     |
| Read/Write         | R/W  | R/W | R/W  | R/W | R/W | R/W | R/W | R/W |
| After reset        | 0    | 0   | 0    | 0   | 0   | 0   | 0   | 0   |

| EDSP | LCD control        | 0: disable |                       |  |  |  |  |
|------|--------------------|------------|-----------------------|--|--|--|--|
|      |                    | 1: enable  | 1: enable             |  |  |  |  |
|      |                    | 000        | 1/4 duty (1/3 bias)   |  |  |  |  |
|      |                    | 001        | 1/3 duty (1/3 bias)   |  |  |  |  |
|      |                    | 010        | 1/3 duty (1/2 bias)   |  |  |  |  |
| DUTY | ICD driving colort | 011        | 1/2 duty (1/2 bias)   |  |  |  |  |
| DOTT | LCD driving select | 100        | Static                |  |  |  |  |
|      |                    | 101        | 1/8 duty (1/4 bias)   |  |  |  |  |
|      |                    | 110        | 1/8 duty (1/3 bias)   |  |  |  |  |
|      |                    | 111        | 1/8 duty (1/2 bias)   |  |  |  |  |
|      |                    | 0000       | fcgck/2 <sup>18</sup> |  |  |  |  |
|      |                    | 0001       | fcgck/2 <sup>17</sup> |  |  |  |  |
|      |                    | 0010       | fcgck/2 <sup>16</sup> |  |  |  |  |
|      |                    | 0011       | fcgck/2 <sup>15</sup> |  |  |  |  |
|      |                    | 0100       | fcgck/2 <sup>14</sup> |  |  |  |  |
|      |                    | 0101       | fcgck/2 <sup>13</sup> |  |  |  |  |
| SLF  | Source clock       | 0110       | fcqck/2 <sup>12</sup> |  |  |  |  |
| _    | selection          | 0111       | System reserved       |  |  |  |  |
|      |                    | 1000       | fs/2 <sup>9</sup>     |  |  |  |  |
|      |                    | 1001       | fs/2 <sup>8</sup>     |  |  |  |  |
|      |                    | 1010       | System reserved       |  |  |  |  |
|      |                    | ~          | ~                     |  |  |  |  |
|      |                    | 1111       | System reconved       |  |  |  |  |
|      |                    | 1111       | System reserved       |  |  |  |  |

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Note 1 : fcgck · Gear clock[Hz] · fs · slow clock [Hz] ·

Note2 : In slow 2 mode, do not set SLF to" 0000"~"0110" (fcgck as basic clock). Otherwise segment and common may output waveform with abnormal frame frequenct.

#### LCD control register 2

| LCDCR2<br>(0x0E7D) | 7   | 6     | 5   | 4    | 3 | 2 | 1 | 0 |
|--------------------|-----|-------|-----|------|---|---|---|---|
| Bit Symbol         |     | HDRTS |     | LDRS | - | - | - | - |
| Read/Write         | R/W | R/W   | R/W | R/W  | R | R | R | R |
| After reset        | 0   | 0     | 0   | 0    | 0 | 0 | 0 | 0 |

|       |              |                |                                  |                   |                   | LC                | DCR1 <sl< th=""><th>.F&gt;</th><th></th><th></th><th></th></sl<> | .F>              |                  |                    |                    |
|-------|--------------|----------------|----------------------------------|-------------------|-------------------|-------------------|------------------------------------------------------------------|------------------|------------------|--------------------|--------------------|
|       |              |                | 0000                             | 0001              | 0010              | 0011              | 0100                                                             | 0101             | 0110             | 1000               | 1001               |
|       |              | 000            |                                  | No connected      |                   |                   |                                                                  |                  |                  |                    |                    |
|       |              | 001            | 211/                             | 210/              | 2%/               | 2 <sup>8</sup> /  | 27/                                                              | 26/              | 25/              | 2 <sup>2</sup> /fs | 2/fs               |
|       |              | 001            | fcgck                            | fcgck             | fcgck             | fcgck             | fcgck                                                            | fcgck            | fcgck            | 2-/15              | 2/13               |
|       |              | 010            | 2 <sup>12</sup> /                | 2 <sup>11</sup> / | 2 <sup>10</sup> / | 2 <sup>9</sup> /  | 2 <sup>8</sup> /                                                 | 2 <sup>7</sup> / | 2 <sup>6</sup> / | 2 <sup>3</sup> /fs | 2 <sup>2</sup> /fs |
|       | Select high- | 010            | fcgck                            | fcgck             | fcgck             | fcgck             | fcgck                                                            | fcgck            | fcgck            |                    |                    |
| HDRTS | 2            | drive time 011 | 2 <sup>13</sup> /                | 2 <sup>12</sup> / | 211/              | 2 <sup>10</sup> / | 2 <sup>9</sup> /                                                 | 2 <sup>8</sup> / | 2 <sup>7</sup> / | 2 <sup>4</sup> /fs | 2 <sup>3</sup> /fs |
|       | unve unie    |                | fcgck                            | fcgck             | fcgck             | fcgck             | fcgck                                                            | fcgck            | fcgck            |                    |                    |
|       |              | 100            | 214/                             | 2 <sup>13</sup> / | 2 <sup>12</sup> / | 211/              | 2 <sup>10</sup> /                                                | 2 <sup>9</sup> / | 2 <sup>8</sup> / | 2 <sup>5</sup> /fs | 2 <sup>4</sup> /fs |
|       |              |                | fcgck                            | fcgck             | fcgck             | fcgck             | fcgck                                                            | fcgck            | fcgck            |                    |                    |
|       |              | 101            | 2 <sup>15</sup> /                | 214/              | 2 <sup>13</sup> / | 2 <sup>12</sup> / | 211/                                                             | 210/             | 2%/              | 26.15              | 25.0               |
|       |              |                | fcgck                            | fcgck             | fcgck             | fcgck             | fcgck                                                            | fcgck            | fcgck            | 2 <sup>6</sup> /fs | 2 <sup>5</sup> /fs |
|       |              | 110            |                                  |                   |                   | Kee               | ep connec                                                        | ted              |                  |                    |                    |
|       |              | 111            |                                  |                   |                   | Sys               | tem reser                                                        | ved              |                  |                    |                    |
|       | Select low-  |                |                                  |                   |                   |                   |                                                                  |                  |                  |                    |                    |
| LDRS  | drive        |                |                                  | low curre         |                   |                   |                                                                  |                  |                  |                    |                    |
|       | current      | 1: select      | 1: select low-drive high current |                   |                   |                   |                                                                  |                  |                  |                    |                    |

Note 1 : fcgck · Gear clock [Hz] · fs · slow clock [Hz]. Note 2 : Bit 3~Bit 0 of LCDCR2 read is "0".

iMQ Technology Inc. No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| LCD Control | Register3 |
|-------------|-----------|
|             |           |

| LCDCR3<br>(0x0E7E) | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|--------------------|---------|---------|---------|---------|---------|---------|---------|---------|
| Bit Symbol         | SEG7_EN | SEG6_EN | SEG5_EN | SEG4_EN | SEG3_EN | SEG2_EN | SEG1_EN | SEG0_EN |
| Read/Write         | R/W     |
| After reset        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

| SEG7_EN | LCD SEG7 pin function select | 0: P74 is other I/O function<br>1: P74 is SEG7 output |
|---------|------------------------------|-------------------------------------------------------|
| SEG6_EN | LCD SEG6 pin function select | 0: P76 is other I/O function<br>1: P76 is SEG6 output |
| SEG5_EN | LCD SEG5 pin function select | 0: P70 is other I/O function<br>1: P70 is SEG5 output |
| SEG4_EN | LCD SEG4 pin function select | 0: P75 is other I/O function<br>1: P75 is SEG4 output |
| SEG3_EN | LCD SEG3 pin function select | 0: P77 is other I/O function<br>1: P77 is SEG3 output |
| SEG2_EN | LCD SEG2 pin function select | 0: P27 is other I/O function<br>1: P27 is SEG2 output |
| SEG1_EN | LCD SEG1 pin function select | 0: P26 is other I/O function<br>1: P26 is SEG1 output |
| SEG0_EN | LCD SEG0 pin function select | 0: P25 is other I/O function<br>1: P25 is SEG0 output |

Note: When LCD enable, set LCD related pins(COM ans SEG) to input mode.

#### LCD Control Register 4

| LCDCR4<br>(0x0E7F) | 7 | 6 | 5 | 4 | 3        | 2        | 1       | 0       |
|--------------------|---|---|---|---|----------|----------|---------|---------|
| Bit Symbol         |   |   |   |   | SEG11_EN | SEG10_EN | SEG9_EN | SEG8_EN |
| Read/Write         | R | R | R | R | R/W      | R/W      | R/W     | R/W     |
| After reset        | 0 | 0 | 0 | 0 | 0        | 0        | 0       | 0       |

| SEG11_EN | LCD SEG11 pin function select | 0: P44 is other I/O function |  |  |
|----------|-------------------------------|------------------------------|--|--|
|          | ECD SEGTI piritunction select | 1: P44 is SEG11 output       |  |  |
| SEG10_EN | LCD SEG10 pin function select | 0: P45 is other I/O function |  |  |
|          |                               | 1: P45 is SEG10 output       |  |  |
| SEG9_EN  | LCD SEG9 pin function select  | 0: P46 is other I/O function |  |  |
|          |                               | 1: P46 is SEG9 output        |  |  |
| SEG8_EN  | LCD SEG8 pin function select  | 0: P47 is other I/O function |  |  |
|          |                               | 1: P47 is SEG8 output        |  |  |

Note: When LCD enable, set LCD related pins(COM ans SEG) to input mode.

iMQ Technology Inc.

#### No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| LCD Control        | Register 5 | 1       |         |         |         |         |         |         |
|--------------------|------------|---------|---------|---------|---------|---------|---------|---------|
| LCDCR5<br>(0x0E80) | 7          | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| Bit Symbol         | COM7_EN    | COM6_EN | COM5_EN | COM4_EN | COM3_EN | COM2_EN | COM1_EN | COM0_EN |
| Read/Write         | R/W        | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |
| After reset        | 0          | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

| COM7_EN  | LCD COM7 pin function | 0: P24 is other I/O function |  |  |
|----------|-----------------------|------------------------------|--|--|
|          | select                | 1: P24 is COM7 output        |  |  |
| COM6 EN  | LCD COM6 pin function | 0: P23 is other I/O function |  |  |
| CONID_EN | select                | 1: P23 is COM6 output        |  |  |
| COM5 EN  | LCD COM5 pin function | 0: P83 is other I/O function |  |  |
| CONS_EN  | select                | 1: P83 is COM5 output        |  |  |
|          | LCD COM4 pin function | 0: P82 is other I/O function |  |  |
| COM4_EN  | select                | 1: P82 is COM4 output        |  |  |
| COM3 EN  | LCD COM3 pin function | 0: P73 is other I/O function |  |  |
|          | select                | 1: P73 is COM3 output        |  |  |
| COM2_EN  | LCD COM2 pin function | 0: P72 is other I/O function |  |  |
|          | select                | 1: P72 is COM2 output        |  |  |
| COM1 EN  | LCD COM1 pin function | 0: P91 is other I/O function |  |  |
|          | select                | 1: P91 is COM1 output        |  |  |
| COM0_EN  | LCD COM0 pin function | 0: P90 is other I/O function |  |  |
|          | select                | 1: P90 is COM0 output        |  |  |

Note: When LCD enable, set LCD related pins(COM ans SEG) to input mode.

## 11.3 Low Power Consumption Function

LCD has the low power consumption register2 (POFFCR2) that saves power consumption when the LCD is not used.

Setting POFFCR2<LCDEN> to "0" disables the basic clock supply to LCD to save power. Note that this makes the LCD function unusable. Setting POFFCR2<LCDEN> to "1" enables the basic clock supply to LCD and allows the LCD function to operate.

After reset, POFFCR2<LCDEN> is initialized to "0", and this makes the LCD unusable. When using the LCD for the first time, be sure to set POFFCR2<LCDEN> to "1" in the initial setting of the program (before the LCD control register is operated).

Do not change POFFCR2<LCDEN> to "0" during the timer operation. Otherwise LCD function may operate unexpectedly.

## 11.4 LCD Driving Function

#### 11.4.1 LCD control Register (LCDCR1<EDSP>)

#### Page: 181/ 278

Setting the LCD control register1 LCDCR1 <EDSP> to "1" activates the LCD function, LCD driving enable, and start LCD display. Setting the LCD control register1 LCDCR1 <EDSP> to "0" stop the LCD function, LCD driving disable, and LCD display stop.Table 11.1 LCD driving pin status when LCD enable or disable

| SEGx_EN | LCDCR1 <edsp></edsp> | Pin status<br>(GPIO \ SEG/COM Outpot) |
|---------|----------------------|---------------------------------------|
| 0       | 0                    | GPIO                                  |
| 0       | 1                    | GPIO                                  |
| 1       | 0                    | Low level                             |
| 1       | 1                    | Segment output                        |

| COMx_EN | LCDCR1 <edsp></edsp> | Pin status<br>(GPIO 	SEG/COM Outpot) |
|---------|----------------------|--------------------------------------|
| 0       | 0                    |                                      |
| 0       | 1                    | GPIO                                 |
| 1       | 0                    | Low level                            |
| 1       | 1                    | Common output                        |

Table 11.1 LCD driving pin status

Note : SEG/COM output no. is "x".

#### 11.4.1.1 Reset

After reset, LCDCR1 <EDSP> are initialized to "0", and this makes the power of LCD display stop automatically, cut VL1,L2,VL3 bias voltage.The bias voltage output pin would be fixed to low-level at this time. LCD driving pin would be GIPO input pin (High-resistro). Therefore, LCD dispay would become not clear if the external reset time is long.

## 11.4.1.2 IDLE0 SLEEP0 and STOP mode

When LCDCR1<EDSP> is "1" in IDLE0,SLEEP0 and STOP modes, LCDCR1 <EDSP> would be initialized to "0", LCD display stop. When out of IDLE0,SLEEP0 and STOP modes , reset LCDCR1 <EDSP> to "1" to enable LCD display. r

#### 11.4.1.3 SLOW mode

Enable LCD function in NORMAL 2 and SLOW 1/2 mode, LCDCR1<SLF> is suggested to set as fs ("1000"到"1001"). In this case, do not need to reset the LCDCR1<SLF> when the operation mode change between NORMAL2 and SLOW1/2.

If the LCD clock is fcgck in normal2 mode, LCDCR1<EDSP> have to clear to "0" before change to SLOW2 mode. In SLOW2 mode, change the LCD clock to fs by LCDCR1<SLF>, and set LCDCR1<EDSP> to "1". Similarly, LCDCR1<EDSP> have to clear to "0" before operation mode chage from SLOW2 to NORMAL2. In NORMAL2 mode, change the LCD clock to fcgk by LCDCR1<SLF>, and set LCDCR1<EDSP> to "1".

## Page: 182 / 278

## 11.4.1.4 LCD clock (LCDCR1<SLF>)

Before LCDCR1<SLF> set"0000" to"0110", enable high-frequency clock (SYSCR2<XEN>="1" or SYSCR2 <OSCEN>="1") and the oscillation is stable . And then set LCDCR1<EDSP> to"1". Set LCDCR1 <EDSP> to"1"would not enable LCD function when high-frequency clock stop. (Set LCDCR1<EDSP> to"1", LCD would not enable)

Similarly, before LCDCR1<SLF> set"0000" to"0110", enable low-frequency clock (SYSCR2<XEN>="1") and the oscillation is stable. And then set LCDCR1<EDSP> to"1". Set LCDCR1 <EDSP> to"1" would not enable LCD function when low-frequency clock stop. (Set LCDCR1<EDSP> to"1", LCD would not enable)

#### 11.4.1.5 The LCD drive of POFFCR2

Set POFFCR2<LCDEN> to "0" would stop LCD display , when LCDCR1<EDSP> is "1". Reset POFFCR2 <LCDEN> to "1" would restart LCD display.

#### 11.4.2 LCD drive mode (LCDCR1<DUTY>)



To select eight LCD drive modse by setting LCDCR1<DUTY>.

#### Page: 183 / 278





Note 2 : VLCD is LCD display voltage ( = VDD – VSS)

#### Page: 184/ 278

#### 11.4.3 Frame frequency (LCDCR1<SLF>)

Frame frequency ( $f_F$ ) is decied by drive mode and clock frequenct. As table 11.2, select clock frequency by LCDCR1<SLF>.

| LCDCR1      | Clock frequency       |                               |                       | Frame Frequency [Hz           | 2]                            |                       |
|-------------|-----------------------|-------------------------------|-----------------------|-------------------------------|-------------------------------|-----------------------|
| <slf></slf> | [Hz]                  | 1/8 bias                      | 1/4 bias              | 1/3 bias                      | 1/2 bias                      | Static                |
| 0000        | fcgck/2 <sup>18</sup> | (4/8) x fcgck/2 <sup>18</sup> | fcgck/2 <sup>18</sup> | (4/3) x fcgck/2 <sup>18</sup> | (4/2) x fcgck/2 <sup>18</sup> | fcgck/2 <sup>18</sup> |
| 0000        | (fcgck = 16MHz)       | 31                            | 61                    | 81                            | 122                           | 61                    |
|             | fcgck/2 <sup>17</sup> | (4/8) x fcgck/2 <sup>17</sup> | fcgck/2 <sup>17</sup> | (4/3) x fcgck/2 <sup>17</sup> | (4/2) x fcgck/2 <sup>17</sup> | fcgck/2 <sup>17</sup> |
| 0001        | (fcgck = 16MHz)       | 61                            | 122                   | 163                           | 244                           | 122                   |
|             | (fcgck = 8MHz)        | 31                            | 61                    | 81                            | 122                           | 61                    |
|             | fcgck/2 <sup>16</sup> | (4/8) x fcgck/2 <sup>16</sup> | fcgck/2 <sup>16</sup> | (4/3) x fcgck/2 <sup>16</sup> | (4/2) x fcgck/2 <sup>16</sup> | fcgck/2 <sup>16</sup> |
| 0010        | (fcgck = 8MHz)        | 61                            | 122                   | 163                           | 244                           | 122                   |
|             | (fcgck = 4MHz)        | 31                            | 61                    | 81                            | 122                           | 61                    |
|             | fcgck/2 <sup>15</sup> | (4/8) x fcgck/2 <sup>15</sup> | fcgck/2 <sup>15</sup> | (4/3) x fcgck/2 <sup>15</sup> | (4/2) x fcgck/2 <sup>15</sup> | fcgck/2 <sup>15</sup> |
| 0011        | (fcgck = 4MHz)        | 61                            | 122                   | 163                           | 244                           | 122                   |
|             | (fcgck = 2MHz)        | 31                            | 61                    | 81                            | 122                           | 61                    |
|             | fcgck/2 <sup>14</sup> | (4/8) x fcgck/2 <sup>14</sup> | fcgck/2 <sup>14</sup> | (4/3) x fcgck/2 <sup>14</sup> | (4/2) x fcgck/2 <sup>14</sup> | fcgck/2 <sup>14</sup> |
| 0100        | (fcgck = 2MHz)        | 61                            | 122                   | 163                           | 244                           | 122                   |
|             | (fcgck = 1MHz)        | 31                            | 61                    | 81                            | 122                           | 61                    |
|             | fcgck/2 <sup>13</sup> | (4/8) x fcgck/2 <sup>13</sup> | fcgck/2 <sup>13</sup> | (4/3) x fcgck/2 <sup>13</sup> | (4/2) x fcgck/2 <sup>13</sup> | fcgck/2 <sup>13</sup> |
| 0101        | (fcgck = 1MHz)        | 61                            | 122                   | 163                           | 244                           | 122                   |
|             | (fcgck = 0.5MHz)      | 31                            | 61                    | 81                            | 122                           | 61                    |
|             | fcgck/2 <sup>12</sup> | (4/8) x fcgck/2 <sup>12</sup> | fcgck/2 <sup>12</sup> | (4/3) x fcgck/2 <sup>12</sup> | (4/2) x fcgck/2 <sup>12</sup> | fcgck/2 <sup>12</sup> |
| 0110        | (fcgck = 0.5MHz)      | 61                            | 122                   | 163                           | 244                           | 122                   |
|             | (fcgck = 0.25MHz)     | 31                            | 61                    | 81                            | 122                           | 61                    |
| 1000        | fs/2 <sup>9</sup>     | (4/8) x fs/2 <sup>9</sup>     | fs/2 <sup>9</sup>     | (4/3) x fs/2 <sup>9</sup>     | (4/2) x fs/2 <sup>9</sup>     | fs/2 <sup>9</sup>     |
| 1000        | (fs = 32.768 KHz)     | 32                            | 64                    | 85                            | 128                           | 64                    |
| 1001        | fs/2 <sup>8</sup>     | (4/8) x fs/2 <sup>8</sup>     | fs/2 <sup>8</sup>     | (4/3) x fs/2 <sup>8</sup>     | (4/2) x fs/2 <sup>8</sup>     | fs/2 <sup>8</sup>     |
| 1001        | (fs = 32.768 KHz)     | 64                            | 128                   | 171                           | 256                           | 128                   |

#### Table 11.2 Frame frequency

Note : fcgck · gear clockHz] · fs · slow clock [Hz] ·

# 11.4.4 High-drive time select (LCDCR2<HDRTS>)and Low-drive current select (LCDCR2<LDRS>)

Generally, LCD drive capacity is higher when connect to high-drive circuit longer, and the power consumption is also higher. On the contrary, LCD drive capacity is lower when connect to high-drive

#### Page: 185 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version : V1.1

circuit shorter, and the power consumption is also lower. LCD display would become no good(e.g. LCD display becom not clear), if LCD drive capacity is not enough. Select the LCD drive to best the LCD display. Table 11.3 shows the estimation of current of LCDCR2<HDRTS>and LCDCR2 <LDRS> and LCD modes.

| LCDCR2          |                    | 1/8 duty | (1/4 bias) | 1/4 duty | (1/3 bias)   | 1/3 duty     | (1/3 bias) | 1/3 duty | (1/2 bias) |      |
|-----------------|--------------------|----------|------------|----------|--------------|--------------|------------|----------|------------|------|
| <hdrts></hdrts> | VDD condition      | LDRS=1   | LDRS=0     | LDRS=1   | LDRS=0       | LDRS=1       | LDRS=0     | LDRS=1   | LDRS=0     | unit |
|                 | High-drive<br>time |          |            | 0 % (al  | ways keep le | ow-driving c | current)   |          |            | %    |
| 000             | VDD = 5V           | 15.60    | 9.52       | 10.91    | 6.77         | 10.91        | 6.77       | 5.69     | 3.75       |      |
|                 | VDD = 3V           | 13.46    | 8.44       | 9.39     | 5.99         | 9.39         | 5.99       | 5.07     | 3.45       | uA   |
|                 | High-drive<br>time |          | 3.13 %     |          |              |              |            |          |            |      |
| 001             | VDD = 5V           | 18.46    | 12.57      | 13.04    | 9.03         | 13.04        | 9.03       | 6.41     | 4.53       |      |
|                 | VDD = 3V           | 15.62    | 10.75      | 10.98    | 7.69         | 10.98        | 7.69       | 5.64     | 4.07       | uA   |
|                 | High-drive<br>time |          | 6.25 %     |          |              |              |            |          |            |      |
| 010             | VDD = 5V           | 21.31    | 15.61      | 15.18    | 11.30        | 15.18        | 11.30      | 7.13     | 5.32       |      |
|                 | VDD = 3V           | 17.78    | 13.07      | 12.57    | 9.38         | 12.57        | 9.38       | 6.20     | 4.68       | uA   |
|                 | High-drive<br>time |          | 12.50 %    |          |              |              |            |          |            | %    |
| 011             | VDD = 5V           | 27.03    | 21.71      | 19.45    | 15.82        | 19.45        | 15.82      | 8.58     | 6.88       |      |
|                 | VDD = 3V           | 22.09    | 17.70      | 15.75    | 12.78        | 15.75        | 12.78      | 7.34     | 5.92       | uA   |
|                 | High-drive<br>time |          |            |          | 25.0         | 00 %         |            |          |            | %    |
| 100             | VDD = 5V           | 38.45    | 33.89      | 27.98    | 24.88        | 27.98        | 24.88      | 11.47    | 10.01      | uA   |
|                 | VDD = 3V           | 30.72    | 26.96      | 22.12    | 19.57        | 22.12        | 19.57      | 9.60     | 8.39       | uA   |
|                 | High-drive<br>time |          | 50.00 %    |          |              |              |            |          |            | %    |
| 101             | VDD = 5V           | 61.30    | 58.26      | 45.06    | 42.99        | 45.06        | 42.99      | 17.25    | 16.28      | uA   |
|                 | VDD = 3V           | 47198    | 45.47      | 34.85    | 33.15        | 34.85        | 33.15      | 14.14    | 13.33      | uA   |
|                 | High-drive<br>time |          |            | 100% (a  | ilways keep  | low-driving  | current)   |          |            | %    |
| 110             | VDD = 5V           | 107.00   | 107.00     | 79.20    | 79.20        | 79.20        | 79.20      | 28.80    | 28.80      |      |
|                 | VDD = 3V           | 82.50    | 82.50      | 60.30    | 60.30        | 60.30        | 60.30      | 23.20    | 23.20      | uA   |

Table 11.3 The List of high-driving current and low-driving current (estimated.)



Figure 11.3 Timing sequency for 1/4 duty (1/3 bias) LCD mode

## 11.5 LCD display data

LCD display data store to display data stoarage area (0x0E40 to 0x0E4B, total 12 bytes)

The data in this area would be read by hardware automatically, and then transfer to LCD drive circuit. LCD drive circuit would follow display data to generate segment and common signal. Therefore, the user can change the display pattern easily by modifying the content in display data storage area.

Blink LCD when display data is "1"; disalbe LCD when display data is "0". At reset, the data in display data area(0x0E40 to 0x0E4B) would be initialized to "0".

Becaouse the LCD pixel is different in different LCD modes, the display data byte would be different. The address not used to storage display data or the address not connect to LCD can used to store general users' data (Table 11.4).

| Driving mode | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------------|-------|-------|-------|-------|-------|-------|-------|-------|
| 1/8 duty     | COM7  | COM6  | COM5  | COM4  | COM3  | COM2  | COM1  | COM0  |
| 1/4 duty     |       |       |       |       | COM3  | COM2  | COM1  | COM0  |
| 1/3 duty     |       |       |       |       |       | COM2  | COM1  | COM0  |
| 1/2 duty     |       |       |       |       |       |       | COM1  | COM0  |
| Static       |       |       |       |       |       |       |       | COM0  |

Table 11.4 The Address for saving display data

## Page: 187 / 278

## 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Registar name     |      |      |      |      |      |      |       |      | Read/  |               |
|-------------------|------|------|------|------|------|------|-------|------|--------|---------------|
| (address)         | Bit7 | Bit6 | Bit5 | Bit4 | Bit3 | Bit2 | Bit 1 | Bit0 | W/rite | Initial value |
| LCDBUF00 (0x0E40) |      |      |      | SE   | G0   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF01 (0x0E41) |      |      |      | SE   | G1   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF02 (0x0E42) |      |      |      | SE   | G2   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF03 (0x0E43) |      |      |      | SE   | G3   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF04 (0x0E44) |      |      |      | SE   | G4   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF05 (0x0E45) |      |      |      | SE   | G5   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF06 (0x0E46) |      |      |      | SE   | G6   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF07 (0x0E47) |      |      |      | SE   | G7   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF08 (0x0E48) |      |      |      | SE   | G8   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF09 (0x0E49) |      |      |      | SE   | G9   |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF10 (0x0E4A) |      |      |      | SEC  | G10  |      |       |      | R/W    | ( 0000 0000 ) |
| LCDBUF11 (0x0E4B) |      |      |      | SEC  | G11  |      |       |      | R/W    | ( 0000 0000 ) |
|                   | COM7 | COM6 | COM5 | COM4 | COM3 | COM2 | COM1  | COM0 |        |               |



## 11.6 The Example of LCD

#### 11.6.1 Initial

The initial LCD driving function flow chart as figure 11.4





#### 11.6.2 Display data setting

Display data is fixed in falsh, and transfer to display data area by specific instruction.

Figure 11.5 is the example of 1/4 duty (1/3 bias) LCD mode. Table 11.6 shows the display data example of 1/4 duty (1/3 bias) LCD

#### Page: 188 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet



Figure 11.5 The example of 1/4 duty (1/3 bias) LCD

| NO. | Display | Display data                     | NO. | Display | Display data                     |
|-----|---------|----------------------------------|-----|---------|----------------------------------|
| 0   | ſ.      | SEG0 =xxxx1111<br>SEG1 =xxxx1101 | 5   | IJ      | SEG0 =xxxx0101<br>SEG1 =xxxx1011 |
| 1   | 00      | SEG0 =xxxx0110<br>SEG1 =xxxx0000 | 6   |         | SEG0 =xxxx0101<br>SEG1 =xxxx1111 |
| 2   |         | SEG0 =xxxx0011<br>SEG1 =xxxx1110 | 7   |         | SEG0 =xxxx0111<br>SEG1 =xxxx0000 |
| 3   | Ŋ       | SEG0 =xxxx0111<br>SEG1 =xxxx1010 | 8   | E       | SEG0 =xxxx0111<br>SEG1 =xxxx1111 |
| 4   |         | SEG0 =xxxx0110<br>SEG1 =xxxx0011 | 9   | IJ      | SEG0 =xxxx0111<br>SEG1 =xxxx1011 |

Table 11.6 The example of display figure "0~9" (1/4 duty, (1/3 bias) LCD)

Figure 11.6 and Table11.7 is the example of 1/2duty (1/2bias) LCD mode. And the example of display figure "0~9".



Figure 11.6 The example of 1/2 duty (1/2 bias) LCD

#### Page: 189/ 278

## 汉芝电子股份有限公司 iMO Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

|        |          | Displa   | ny data  |          |
|--------|----------|----------|----------|----------|
| Number | SEG3     | SEG2     | SEG 1    | SEG0     |
| 0      | xxxxxx01 | xxxxxx11 | xxxxxx01 | xxxxxx11 |
| 1      | xxxxxx00 | xxxxxx10 | xxxxxx00 | xxxxxx10 |
| 2      | xxxxxx10 | xxxxxx01 | xxxxxx01 | xxxxxx11 |
| 3      | xxxxxx10 | xxxxxx10 | xxxxxx01 | xxxxxx11 |
| 4      | xxxxxx11 | xxxxxx10 | xxxxxx00 | xxxxxx10 |
| 5      | xxxxxx11 | xxxxxx10 | xxxxxx01 | xxxxxx01 |
| 6      | xxxxxx11 | xxxxxx11 | xxxxxx01 | xxxxxx01 |
| 7      | xxxxxx01 | xxxxxx10 | xxxxxx00 | xxxxxx11 |
| 8      | xxxxxx11 | xxxxxx11 | xxxxxx01 | xxxxxx11 |
| 9      | xxxxxx11 | xxxxxx10 | xxxxxx01 | xxxxxx11 |

Table 11.7 The example of display figure "0~9" (1/2 duty, (1/2 bias) LCD)

#### 11.6.3 LCD Drive Example

Figure 11.7 figure 11.8 and figure 11.9 are the LCD drive waveform example for 1/4duty (1/3bias), 1/2 duty (1/2 bias) and static LCD separately.



Figure 11.7 LCD drive waveform examples for 1/4 duty (1/3 bias) LCD

#### Page: 190/ 278

## 汉芝电子股份有限公司

#### iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1







Figure 11.9 LCD drive waveform examples for static LCD

#### Page: 191/ 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## 12.Asynchronous Serial Interface (UART)

MQ6812/MQ6821 contains 1 channels of asynchronous serial interfaces (UART). This chapter describes asynchronous serial interface 1 (UART1), as shown in Table 12.1 and Table 12.2.

|       | UARTxCR1  | UARTxCR2  | UARTxDR   | UARTxSR   | RDxBUF    | TDxBUF    |
|-------|-----------|-----------|-----------|-----------|-----------|-----------|
|       | (Address) | (Address) | (Address) | (Address) | (Address) | (Address) |
| UART1 | UART1CR1  | UART1CR2  | UART1DR   | UART1SR   | RD1BUF    | TD1BUF    |
|       | (0x0F54)  | (0x0F55)  | (0x0F56)  | (0x0F57)  | (0x0F58)  | (0x0F58)  |

#### Table 12.1 SFR Address Assignment

|       | Serial Data Input Pin | Serial Data Output Pin |
|-------|-----------------------|------------------------|
| UARTI | RXD1 pin              | TXD1 pin               |

#### Table 12.2 Pin Names

## 12.1 Control

UART1 is controlled by the low power consumption registers (POFFCR1), UART1 control registers 1 and 2 (UART1CR1 and UART1CR2) and the UART1 baud rate register (UART1DR). The operating status can be monitored using the UART status register (UART1SR).

#### Low Power Consumption Register 1

| POFFCR1<br>(0x0F75) | 7   | 6   | 5   | 4      | 3 | 2 | 1       | 0 |
|---------------------|-----|-----|-----|--------|---|---|---------|---|
| Bit Symbol          | -   | -   | -   | SBIOEN | - | - | UART1EN | - |
| Read/Write          | R/W | R/W | R/W | R/W    | R | R | R/W     | R |
| After reset         | 0   | 0   | 0   | 0      | 0 | 0 | 0       | 0 |

| SBIOEN  | I2C0 control  | 0: Disable<br>1: Enable |
|---------|---------------|-------------------------|
| UART1EN | UART1 control | 0: Disable<br>1: Enable |

#### Page: 192 / 278

## 汉芝电子股份有限公司 iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| UART1 | Control | Register 1 |  |
|-------|---------|------------|--|
|       |         | -          |  |

| UART1CR1<br>(0x0F54) | 7   | 6   | 5      | 4    | 3   | 2       | 1   | 0 |
|----------------------|-----|-----|--------|------|-----|---------|-----|---|
| Bit Symbol           | TXE | RXE | STOPBT | EVEN | PE  | IRDASEL | BRG | - |
| Read/Write           | R/W | R/W | R/W    | R/W  | R/W | R/W     | R/W | R |
| After reset          | 0   | 0   | 0      | 0    | 0   | 0       | 0   | 0 |

| TXE     | Transmit operation                   | 0: Disable<br>1: Enable                          |                                    |        |  |
|---------|--------------------------------------|--------------------------------------------------|------------------------------------|--------|--|
| RXE     | Receive operation                    | -                                                | 0: Disable<br>1: Enable            |        |  |
| STOPBT  | Transmit stop bit length             | 0: 1<br>1: 2                                     |                                    |        |  |
| ТАОМСАР | Pulse width measurement mode control | 0: Double edge capture<br>1: Single edge capture |                                    |        |  |
| EVEN    | Parity selection                     | 0: Odd-numbered parity<br>1: Even number parity  |                                    |        |  |
| PE      | Parity addition                      |                                                  | o parity<br>Irity added            |        |  |
| IRDASEL | TXD pin output selectin              |                                                  | ART output<br>DA output            |        |  |
|         |                                      |                                                  | When SYSCR2 <sysck> is "1"</sysck> |        |  |
| BRG     | Transfer base clock selection        | 0                                                | fcgck                              | fs     |  |
|         |                                      | 1                                                | TCA0                               | output |  |

Note 1): fcgck, Gear clock; fs, Low-frequency clock

Note 2]: If the TXE or RXE bit is set to "0" during the transmission or receiving of data, the operation is not disabled until the data transfer is completed. At this time, the data stored in the transmit data buffer is discarded.

Note 3): EVEN, PE and BRG settings are common to transmission and receiving.

Note 4): Set RXE and TXE to "0" before changing BRG.

Note 5]: When BRG is set to the TCAO output, the RT clock becomes asynchronous and the start bit of the transmitted/received data may get shorter by a maximum of (UART1DR+1)/(Transfer base clock frequency)[s]. If the pin is not used for the TCA0 output, control the TCA0 output by using the port function control register.

Note 6): To prevent STOPBT, EVEN, PE, IRDASEL and BRG from being changed accidentally during the UART communication, the register cannot be rewritten during the UART operation. For details, refer to "12.3 Protection to Prevent UART1CR1 and UART1CR2 Registers from Being Changed ".

Note 7]: When the STOP, IDLEO or SLEEPO mode is activated, TXE and RXE are cleared to "O" and the UART stops. Other bits keep their values.

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| UART1 | Control | Register 2 |
|-------|---------|------------|
|       |         | -          |

| UART1CR2<br>(0x0F55) | 7 | 6 | 5 | 4     | 3 | 2   | 1      | 0   |
|----------------------|---|---|---|-------|---|-----|--------|-----|
| Bit Symbol           | - | - |   | RTSEL |   | RXE | STOPBR |     |
| Read/Write           | R | R |   | R/W   |   |     | W/     | R/W |
| After reset          | 0 | 0 | 0 | 0     | 0 | 0   | 0      | 0   |

|        |                                                                                          |                       | Odd-numbered bits of<br>transfer frame                               | Even-numbered bits of<br>transfer frame |  |
|--------|------------------------------------------------------------------------------------------|-----------------------|----------------------------------------------------------------------|-----------------------------------------|--|
|        | RTSEL Selects the number of RT clocks                                                    | 000                   | 16 clocks                                                            | 16 clocks                               |  |
|        |                                                                                          | 001                   | 16 clocks                                                            | 17 clocks                               |  |
| RTSEL  |                                                                                          | 010                   | 15 clocks                                                            | 15 clocks                               |  |
|        |                                                                                          | 011                   | 15 clocks                                                            | 16 clocks                               |  |
|        |                                                                                          | 100                   | 17 clocks                                                            | 17 clocks                               |  |
|        |                                                                                          | 101                   | rved                                                                 |                                         |  |
|        |                                                                                          | 11*                   | Rese                                                                 | rved                                    |  |
| RXDNC  | Selects the RXD input noise<br>rejection time (Time of pulses to<br>be removed as noise) | 10: 2 x               | clock frequency) [s]<br>clock frequency) [s]<br>clock frequency) [s] |                                         |  |
| STOPBR | Receive stop bit length                                                                  | 0: 1 bit<br>1: 2 bits |                                                                      |                                         |  |

Note 1): When a read instruction is executed on UART1CR2, bits 7 and 6 are read as "0".

Note 2): RTSEL can be set to two kinds of RT clocks for the even- and odd-numbered bits of the transfer frame. For details, refer to "12.7.1 Transfer baud rate calculation method".

Note 3]: For details of the RXDNC noise rejection time, refer to "12.9 Received Data Noise Rejection".

Note 4): When the STOP, IDLE0 or SLEEP0 mode is activated, the UART stops automatically but each bit value of UART1CR2 remains unchanged.

Note 5/: When STOPBR is set to 2 bits, the first bit of the stop bits (during data receiving) is not checked for a framing error.

Note 6]: To prevent RTSEL, RXDNC and STOPBR from being changed accidentally during the UART communication, the register cannot be rewritten during the UART operation. For details, refer to "12.3 Protection to Prevent UART1CR1 and UART1CR2 Registers from Being Changed ".

| UART1DR<br>(0x0F56) | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|---------------------|----------|----------|----------|----------|----------|----------|----------|----------|
| Bit Symbol          | UART1DR7 | UART1DR6 | UART1DR5 | UART1DR4 | UART1DR3 | UART1DR2 | UART1DR1 | UART1DR0 |
| Read/Write          | R/W      |
| After reset         | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |

#### UART1 Baud Rate Register

Note 1): Set UART1CR1<RXE> and UART1CR1<TXE> to "0" before changing UART1DR. For the set values, refer to "12.7 Transfer Baud Rate".

Note 2]: When UART1CR1<BRG> is set to the TCA0 output, the value set to UART1DR has no meaning.

Note 3): When the STOP, IDLE0 or SLEEPO

#### Page: 194/ 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

#### **UART1** Status Register

| UAR01SR<br>(0x0F57) | 7    | 6    | 5    | 4 | 3    | 2    | 1    | 0    |
|---------------------|------|------|------|---|------|------|------|------|
| Bit Symbol          | PERR | FERR | OERR | - | RBSY | RBFL | TBSY | TBFL |
| Read/Write          | R    | R    | R    | R | R    | R    | R    | R    |
| After reset         | 0    | 0    | 0    | 0 | 0    | 0    | 0    | 0    |

| PERR  | Parity error flag         | 0: No parity error<br>1: Parity error                               |
|-------|---------------------------|---------------------------------------------------------------------|
| RFERR | Framing error flag        | 0: No framing error<br>1: Framing error                             |
| OERR  | Overrun error flag        | 0: No overrun error<br>1: Overrun error                             |
| RBSY  | Receive busy flag         | 0: Before receiving or end of receiving<br>1: On receiving          |
| RBFL  | Receive buffer full flag  | 0: Receive buffer empty<br>1: Receive buffer full                   |
| TBSY  | Transmit busy flag        | 0: Before transmission or end of transmission<br>1: On transmission |
| TBFL  | Transmit buffer full flag | 0: Transmit buffer empty<br>1: Transmit buffer full                 |

Note 1): TBFL is cleared to "0" automatically after an INTTXD1 interrupt request is generated, and is set to "1" when data is set to TD IBUF.

Note 2]: When a read instruction is executed on UART1SR, bit 4 is read as "0".

Note 3]: When the STOP, IDLE0 or SLEEP0 mode is activated, each bit of UART1SR is cleared to "0" and the UART stops.

#### **UART1** Receive Data Register

| RD1BUF<br>(0x0F58) | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Bit Symbol         | RD1DR7 | RD1DR6 | RD1DR5 | RD1DR4 | RD1DR3 | RD1DR2 | RD1DR1 | RD1DR0 |
| Read/Write         | R      | R      | R      | R      | R      | R      | R      | R      |
| After reset        | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Note]: When the STOP, IDLE0 or SLEEP0 mode is activated, the RD IBUF values become undefined. If received data is required, read it before activating the mode.

#### **UART1** Transmit Data Register

| TD1BUF<br>(0x0F58) | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Bit Symbol         | TD1DR7 | TD1DR6 | TD1DR5 | TD1DR4 | TD1DR3 | TD1DR2 | TD1DR1 | TD1DR0 |
| Read/Write         | W      | W      | W      | W      | W      | W      | W      | W      |
| After reset        | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Note): When the STOP, IDLE0 or SLEEP0 mode is activated, the TD1BUF values become undefined.

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 12.2 Low Power Consumption Function

UART1 has a low power consumption register (POFFCR1) that saves power consumption when the UART function is not used.

Setting POFFCR1 <UART1EN> to "0" disables the basic clock supply to UART1 to save power. Note that this renders the UART unusable. Setting POFFCR1 <UART1EN> to "1" enables the basic clock supply to UART1 and renders the UART usable.

After reset, POFFCR1 <UART1EN> is initialized to "0", and this renders the UART unusable. When using the UART for the first time, be sure to set POFFCR1 <UART1EN> to "1" in the initial setting of the program (before the UART control register is operated).

Do not change POFFCR1 <UART1EN> to "0" during the UART operation, otherwise UART1 may operate unexpectedly.

## 12.3 Protection of UART1CR1 and UART1CR2 Registers from Being Changed

MQ6812/MQ6821 has a function that protects the registers from being changed so that the UART communication settings (for example, stop bit and parity) are not changed accidentally during the UART operation.

Specific bits of UART1CR1 and UART1CR2 can be changed only under the conditions shown in Table 11.3. If a write instruction is executed on the register when it is protected from being changed, the bits remain unchanged and keep their previous values.

|                              |                               | Conditions that allow the bit to be changed |                       |                           |                       |  |  |  |
|------------------------------|-------------------------------|---------------------------------------------|-----------------------|---------------------------|-----------------------|--|--|--|
| Bit to be changed            | Function                      | UART1CR1 <txe></txe>                        | UART1SR <tbsy></tbsy> | UART1CR1 <rxe></rxe>      | UART1SR <rbsy></rbsy> |  |  |  |
| UART1CR1 <stopbt></stopbt>   | Transmit stop it length       | Both of thease bits are                     | "0"                   | -                         | -                     |  |  |  |
| UART1CR1 <even></even>       | Parity selection              |                                             |                       |                           |                       |  |  |  |
| UART1CR1 <pe></pe>           | Parity selection              | All of these bits are "0"                   |                       |                           |                       |  |  |  |
| UART1CR1 <irdasel></irdasel> | TXD pin output selection      | Both of thease bits are "0"                 |                       |                           |                       |  |  |  |
| UART1CR1 <brg></brg>         | Transfer base clock selection |                                             |                       |                           |                       |  |  |  |
| UART1CR2 <rtsel></rtsel>     | Selection of number of RT     | All of these bits are "0'                   |                       |                           |                       |  |  |  |
|                              | clocks                        |                                             |                       |                           |                       |  |  |  |
| UART1CR2 <rxdnc></rxdnc>     | Selection of RXD pin input    |                                             |                       |                           |                       |  |  |  |
|                              | noise rejection time          | -                                           | -                     | All of these bits are "0" |                       |  |  |  |
| UART1CR2 <stopbr></stopbr>   | Receive stop bit length       | -                                           | -                     | All of these bits are "   | 0″                    |  |  |  |

#### Table 12.3 Changing of UART1CR1 and UART1CR2

#### Page: 196 / 278

## 12.4 Activation of STOP, IDLE0 or SLEEP0 Mode

#### 12.4.1 Transition of Register Status

When the STOP, IDLE0 or SLEEP0 mode is activated, the UART stops automatically and each register becomes the status as shown in Table 12.4. For the registers that do not hold their values, make settings again as needed after the operation mode is recovered.

|          | 7                   | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | 0                  |
|----------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--------------------|
|          | TXE                 | RXE                 | STOPBT              | EVEN                | PE                  | IRDASEL             | BRG                 | -                  |
| UART1CR1 | Cleared to 0        | Cleared to 0        | Hold the val-<br>ue | -                  |
|          | -                   | -                   |                     | RTSEL               |                     | RXI                 | ONC                 | STOPBR             |
| UART1CR2 | -                   | -                   | Hold the val-<br>ue | Hold the value     |
| UART1SR  | PERR                | FERR                | OERR                | -                   | RBSY                | RBFL                | TBSY                | TBFL               |
| UANTISK  | Cleared to 0        | Cleared to 0        | Cleared to 0        | -                   | Cleared to 0        | Cleared to 0        | Cleared to 0        | Cleared to 0       |
|          | UART1DR7            | UART1DR6            | UART1DR5            | UART1DR4            | UART1DR3            | UART1DR2            | UART1DR1            | UART1DR0           |
| UART1DR  | Hold the val-<br>ue | Hold the value     |
|          | RD1DR7              | RD1DR6              | RD1DR5              | RD1DR4              | RD1DR3              | RD1DR2              | RD1DR1              | RD1DR0             |
| RD1BUF   | Indetermi-<br>nate  | Indetermi-<br>nate |
|          | TD1DR7              | TD1DR6              | TD1DR5              | TD1DR4              | ·TD1DR3             | TD1DR2              | TD1DR1              | TD1DR0             |
| TD1BUF   | Indetermi-<br>nate  | Indetermi-<br>nate |

Table 12.4 Transition of Register Status

## 12.4.2 Transition of TXD Pin Status

When the IDLE0, SLEEP0 or STOP mode is activated, the TXD pin reverts to the status shown in Table 11.5, whether data is transmitted/received or the operation is stopped.

| UART1CR1            |                      | STOP mode                  |                            |  |  |  |
|---------------------|----------------------|----------------------------|----------------------------|--|--|--|
| <irdasel></irdasel> | IDEL0 or SLEEP0 mode | SYSCR1 <outen>="1"</outen> | SYSCR1 <outen>="0"</outen> |  |  |  |
| "0"                 | H level              | H level                    | 11:7                       |  |  |  |
| "1"                 | L level              | L level                    | Hi-Z                       |  |  |  |

Table 12.5 TXD Pin Status When the STOP, IDLE0 or SLEEP0 Mode Is Activated

## 12.5 Transfer Data Format

The UART transfers data composed of the following four elements. The data from the start bit to the stop

## Page: 197 / 278

bit is collectively defined as a "transfer frame". The start bit consists of 1 bit (L level) and the data consists of 8 bits. Parity bits are determined by UART1CR1 <PE> that selects the presence or absence of parity and UART1CR1 <EVEN> that selects even- or odd-numbered parity. The bit length of the stop bit can be selected at UART1CR1 <STBT>.

Figure 12.1 shows the transfer data format.

- Start bit (1 bit)
- Data (8 bits)
- Parity bit (selectable from even-numbered, odd-numbered or no parity)
- Stop bit (selectable from 1 bit or 2 bits)

|    |      | Transfer frame |         |       |       |         |       |       |       |       |        |        |        |
|----|------|----------------|---------|-------|-------|---------|-------|-------|-------|-------|--------|--------|--------|
| PE | STBT | 1              | 2       | 3     | 4     | 5       | 6     | 7     | 8     | 9     | 10     | 11     | 12     |
| 0  | 0    | Start          | (Bit 0) | Bit 1 | Bit 2 | (Bit 3) | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Stop 1 |        |        |
| 0  | 1    | Start          | Bit 0   | Bit 1 | Bit 2 | (Bit 3) | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Stop 1 | Stop 2 |        |
| 1  | 0    | Start          | Bit 0   | Bit 1 | Bit 2 | (Bit 3) | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Parity | Stop 1 |        |
| 1  | 1    | Start          | Bit 0   | Bit 1 | Bit 2 | (Bit 3) | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Parity | Stop 1 | Stop 2 |

Figure 12.1 Transfer Data Format

## 12.6 Infrared Data Format Transfer Mode

The TXD1 pin can output data in the infrared data format (IrDA) by the setting of the IrDA output control register. Setting UART1CR1 <IRDASEL> to "1" allows the TXD1 pin to output data in the infrared data format.





## Page: 198 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

## 12.7 Transfer Baud Rate

The transfer baud rate of UART is set by UART1CR1 <BRG>, UART1DR and UART1CR2<RTSEL>. The settings of UART1DR and UART1CR2 <RTSEL> for general baud rates and operating frequencies are shown below. For independent calculation of transfer baud rates, refer to "11.7.1 Transfer baud rate calculation method".

| Basic baud | De sister    |          | Ope      | erating freque | ency     |          |
|------------|--------------|----------|----------|----------------|----------|----------|
| rate[baud] | Register     | 16MHz    | 8MHz     | 4MHz           | 2MHz     | 1MHz     |
|            | UART1DR[7:0] | 0x07     | 0x03     | 0x01           | 0x00     | -        |
| 128000     | RTSEL[2:0]   | 0y011    | 0y011    | 0y011          | 0y011    | -        |
|            | Error        | (+0.81%) | (+0.81%) | (+0.81%)       | (+0.81%) | -        |
|            | UART1DR[7:0] | 0x08     | 0x03     | 0x01           | 0x00     | -        |
| 115200     | RTSEL[2:0]   | 0y011    | 0y100    | 0y100          | 0y100    | -        |
|            | Error        | (-0.44%) | (+2.12%) | (+2.12%)       | (+2.12%) | -        |
|            | UART1DR[7:0] | 0x0C     | 0x06     | 0x02           | -        | -        |
| 76800      | RTSEL[2:0]   | 0y000    | 0y010    | 0y100          | -        | -        |
|            | Error        | (+0.16%) | (-0.79%) | (+2.12%)       | -        | -        |
|            | UART1DR[7:0] | 0x0F     | 0x07     | 0x03           | 0x01     | 0x00     |
| 62500      | RTSEL[2:0]   | 0y000    | 0y000    | 0y000          | 0y000    | 0y000    |
|            | Error        | 0%       | 0%       | 0%             | 0%       | 0%       |
|            | UART1DR[7:0] | 0x11     | 0x08     | 0x03           | 0x01     | 0x00     |
| 57600      | RTSEL[2:0]   | 0y011    | 0y011    | 0y100          | 0y100    | 0y100    |
|            | Error        | (-0.44%) | (-0.44%) | (+2.12%)       | (+2.12%) | (+2.12%) |
|            | UART1DR[7:0] | 0x19     | 0x0C     | 0x06           | 0x02     | -        |
| 38400      | RTSEL[2:0]   | 0y000    | 0y000    | 0y010          | 0y100    | -        |
|            | Error        | (+0.16%) | (+0.16%) | (-0.79%)       | (+2.12%) | -        |
|            | UART1DR[7:0] | 0x30     | 0x19     | 0x0C           | 0x06     | 0x02     |
| 19200      | RTSEL[2:0]   | 0y100    | 0y000    | 0y000          | 0y010    | 0y100    |
|            | Error        | (+0.04%) | (+0.16%) | (+0.16%)       | (-0.79%) | (+2.12%) |
|            | UART1DR[7:0] | 0x64     | 0x33     | 0x19           | 0x0C     | 0x06     |
| 9600       | RTSEL[2:0]   | 0y001    | 0y000    | 0y000          | 0y000    | 0y010    |
|            | Error        | (+0.01%) | (+0.16%) | (+0.16%)       | (+0.16%) | (-0.79%) |
|            | UART1DR[7:0] | 0xC9     | 0x67     | 0x33           | 0x19     | 0x0C     |
| 4800       | RTSEL[2:0]   | 0y001    | 0y000    | 0y000          | 0y000    | 0y000    |
|            | Error        | (+0.01%) | (+0.16%) | (+0.16%)       | (+0.16%) | (+0.16%) |
|            | UART1DR[7:0] | -        | 0xCF     | 0x67           | 0x33     | 0x19     |
| 2400       | RTSEL[2:0]   | -        | 0y000    | 0y000          | 0y000    | 0y000    |
|            | Error        | -        | (+0.16%) | (+0.16%)       | (+0.16%) | (+0.16%) |
|            | UART1DR[7:0] | -        | -        | 0xCF           | 0x67     | 0x33     |
| 1200       | RTSEL[2:0]   | -        | -        | 0y000          | 0y000    | 0y000    |
|            | Error        | -        | -        | (+0.16%)       | (+0.16%) | (+0.16%) |

## 12.7.1 Transfer Baud Rate Calculation Method

The bit width of transmitted/received data can be finely adjusted by changing UART1CR2 <RTSEL>. The number of RT clocks per bit can be changed in a range of 15 to 17 clocks by changing UART1CR2<RTSEL>. The RT clock is the transfer base clock, which is the pulses obtained by counting the clock selected at UART1CR1<BRG> the number of times of (UART1DR set value) + 1. Especially, when UART1CR2 <RTSEL> is set to "0y001" or "0y011", two types of RT clocks alternate at each bit, so that the pseudo baud rates of RT × 15.5 clocks and RT × 16.5 clocks can be generated. The number of RT clocks per bit of transfer frame is shown in Figure 12.3.

For example, when fcgck is 4 [MHz], UART1CR2<RTSEL> is set to "0y000" and UART1DR is set to "0x19", the baud rate calculated using the formula in Figure 11.3 is expressed as:fcgck / ( $16 \times (UART1DR + 1) = 9615$  [baud]

|    |      | _ |       |       |                  |                 |         | Transfe | er frame |       |       |                  |                  |        |                                 |
|----|------|---|-------|-------|------------------|-----------------|---------|---------|----------|-------|-------|------------------|------------------|--------|---------------------------------|
| PE | STBT |   | 1     | 2     | 3                | 4               | 5       | 6       | 7        | 8     | 9     | 10               | 11               | 12     |                                 |
| 0  | 0    |   | Start | Bit 0 | (Bit 1)          | Bit 2           | (Bit 3) | (Bit 4) | Bit 5    | Bit 6 | Bit 7 | Stop 1           | -                |        |                                 |
| 0  | 1    |   | Start | Bit 0 | (Bit 1)          | Bit 2           | (Bit 3) | (Bit 4) | Bit 5    | Bit 6 | Bit 7 | Stop 1           | Stop 2           |        |                                 |
| 1  | 0    | ٦ | Start | Bit 0 | (Bit 1)          | Bit 2           | (Bit 3) | (Bit 4) | Bit 5    | Bit 6 | Bit 7 | Parity           | Stop 1           |        |                                 |
| 1  | 1    |   | Start | Bit 0 | (Bit 1)          | Bit 2           | (Bit 3) | (Bit 4) | Bit 5    | Bit 6 | Bit 7 | Parity           | Stop 1           | Stop 2 |                                 |
| RT | SEL  |   | 1     |       | 1<br>1<br>1<br>1 | 1<br> <br> <br> | Nu      | mber of | RT clo   | cks   |       | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 |        | Generated baud rate             |
| 0  | 00   |   | 16    | 16    | 16               | 16              | 16      | 16      | 16       | 16    | 16    | 16               | 16               | 16     | fcgck<br>16×(UARTDR+1) [baud]   |
| 0  | 01   |   | 16    | 17    | 16               | 17              | 16      | 17      | 16       | 17    | 16    | 17               | 16               | 17     | fcgck<br>16.5×(UARTDR+1) [baud] |
| 0  | 10   |   | 15    | 15    | 15               | 15              | 15      | 15      | 15       | 15    | 15    | 15               | 15               | 15     | fogck<br>15×(UARTDR+1) [baud]   |
| 0  | 11   |   | 15    | 16    | 15               | 16              | 15      | 16      | 15       | 16    | 15    | 16               | 15               | 16     | fogck<br>15.5×(UARTDR+1) [baud] |
| 1  | 00   |   | 17    | 17    | 17               | 17              | 17      | 17      | 17       | 17    | 17    | 17               | 17               | 17     | fcgck<br>17×(UARTDR+1) [baud]   |

These settings generate a baud rate close to 9600 [baud] (+0.16%).

\*When BRG is set to fcgck

Figure 12.3 Fine Adjustment of Baud Rate Clock Using UART11R2 <RTSEL>

## 12.7.1.1 Calculation of Set Values of UART1CR2 <RTSEL> and UART1DR

The set value of UART1DR for an operating frequency and baud rate can be calculated using the calculation formula shown in Figure 12.4. For example, to generate a basic baud rate of 38400 [baud] with fcgck=4 [MHz], calculate the set value of UART1DR for each setting of UART1CR2 <RTSEL> and compensate the calculated value to a positive number to obtain the generated baud rate as shown in Figure 12.5. Basically, select the set value of UART1CR2 <RTSEL> that has the smallest baud rate error from among the generated baud rates. In Figure 12.5, the setting of UART1CR2 <RTSEL>="0y010" has the smallest error among the calculated baud rates, and thus the

## Page: 200 / 278

generated baud rate is 38095 [baud] (-0.79%) against the basic baud rate of 38400 [baud].

Note]: The error from the basic baud rate should be accurate to within  $\pm 3\%$ . Even if the error is within  $\pm 3\%$ , the communication may fail due to factors such as frequency errors of external controllers (for example, a personal computer) and oscillators and the load capacity of the communication pin.

| RTSEL | UARTDR set value                                       |
|-------|--------------------------------------------------------|
| 000   | $UARTDR = \frac{fcgck [Hz]}{16 \times A [baud]} - 1$   |
| 001   | $UARTDR = \frac{fcgck [Hz]}{16.5 \times A [baud]} - 1$ |
| 010   | $UARTDR = \frac{fcgck [Hz]}{15 \times A [baud]} - 1$   |
| 011   | $UARTDR = \frac{fcgck [Hz]}{15.5 \times A [baud]} - 1$ |
| 100   | $UARTDR = \frac{fcgck [Hz]}{17 \times A [baud]} - 1$   |

| RTSEL | UARTDR calculation                                                                     | Generated baud rate                                                                 |
|-------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| 000   | UARTDR = $\frac{4000000 \text{ [Hz]}}{16 \times 38400 \text{ [baud]}} -1 \approx 6$    | $\frac{4000000 \text{ [Hz]}}{16 \times (6 + 1)} = 35714 \text{ [baud]} (-6.99\%)$   |
| 001   | UARTDR = $\frac{4000000 [Hz]}{16.5 \times 38400 [baud]} - 1 \approx 5$                 | $\frac{4000000 \text{ [Hz]}}{16.5 \times (5 + 1)} = 40404 \text{ [baud]} (+5.22\%)$ |
| 010   | UARTDR = $\frac{4000000 \text{ [Hz]}}{15 \times 38400 \text{ [baud]}} -1 \approx 6$    | $\frac{4000000 \text{ [Hz]}}{15 \times (6 + 1)} = 38095 \text{ [baud]} (-0.79\%)$   |
| 011   | UARTDR = $\frac{4000000 \text{ [Hz]}}{15.5 \times 38400 \text{ [baud]}} - 1 \approx 6$ | $\frac{4000000 \text{ [Hz]}}{15.5 \times (6 + 1)} = 36866 \text{ [baud]} (-3.99\%)$ |
| 100   | UARTDR = $\frac{4000000 [Hz]}{17 \times 38400 [baud]} -1 \approx 5$                    | $\frac{4000000 \text{ [Hz]}}{17 \times (5 + 1)} = 39216 \text{ [baud]} (+2.12\%)$   |

#### Figure 12.5 Example of UART1DR Calculation

## 12.8 Data Sampling Method

The UART receive control circuit starts RT clock counting when it detects a falling edge of the input pulses to the RXD1 pin. 15 to 17 RT clocks are counted per bit and each clock is expressed as RTn (n=16 to 0). In a bit that has 17 RT clocks, RT16 to RT0 are counted. In a bit that has 16 RT clocks, RT15 to RT0 are counted. In a bit that has 15 RT clocks, RT14 to RT0 are counted (Decrement). During counting of RT8 to RT6, the UART receive control circuit samples the input pulses to the RXD1 pin to make a majority decision. The same level detected twice or more from among three samplings is processed as the data for the bit.

The number of RT clocks can be changed in a range of 15 to 17 by setting UART1CR2 <RTSEL>. However, sampling is always executed in RT8 to RT6, even if the number of RT clocks is changed (Figure 12.6).

#### Page: 201/ 278

## 汉芝电子股份有限公司



#### Figure 12.6 Data Sampling in Each Case of UART1CR2 <RTSEL>

If "1" is detected in sampling of the start bit, for example, due to the influence of noise, RT clock counting stops and the data receiving is suspended. Subsequently, when a falling edge is detected in the input pulses to the RXD1 pin, RT clock counting restarts and the data receiving restarts with the start bit.

## Page: 202 / 278

## 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1



Figure 12.7 Start Bit Sampling

## 12.9 Received Data Noise Rejection

When noise rejection is enabled at UART1CR2 <RXDNC>, the time of pulses to be regarded as signals is as shown in Table 12.6.

| RXDNC | Noise rejection time(s)                        | Time of pulses to be regarded as signals       |
|-------|------------------------------------------------|------------------------------------------------|
| 00    | NO noise rejection                             | -                                              |
| 01    | (UART1DR+1)/(Transfer base clock frequency)    | 2x (UART1DR+1)/(Transfer base clock frequency) |
| 10    | 2x (UART1DR+1)/(Transfer base clock frequency) | 4x (UART1DR+1)/(Transfer base clock frequency) |
| 11    | 4x (UART1DR+1)/(Transfer base clock frequency) | 8x (UART1DR+1)/(Transfer base clock frequency) |

#### Table 12.6 Received Data Noise Rejection Time

Note): The transfer base clock frequency is the clock frequency selected at UARTCR1 <BRG>.



## Page: 203 / 278

## 12.10 Transmit/Receive Operation

#### 12.10.1 Data Transmit Operation

Set UART1CR1 <TXE> to "1". Check UART1SR <TBFL> = "0", and then write data into TD1BUF (transmit data buffer). Writing data into TD1BUF sets UART1SR<TBFL> to "1", transfers the data to the transmit shift register, and outputs the data sequentially from the TXD1 pin. The data output includes a start bit, stop bits whose number is specified in UART1CR1 <STBT> and a parity bit if parity addition is specified. Select the data transfer baud rate using UART1CR1 <BRG>, UART1CR2 <RTSEL> and UART1DR. When data transmission starts, the transmit buffer full flag UART1SR <TBFL> is cleared to "0" and an INTTXD1 interrupt request is generated.

Note 1): After data is written into TD1BUF, if new data is written into TD1BUF before the previous data is transferred to the shift register, the new data is written over the previous data and is transferred to the shift register.

Note 2): Under the conditions shown in Table 12.7, the TXD1 pin output is fixed at the L or H level according to the setting of UART1CR1 <IRDASEL>.

| Condition                                                                                                   | TXD1 pin output |             |  |  |
|-------------------------------------------------------------------------------------------------------------|-----------------|-------------|--|--|
| Condition                                                                                                   | IRDASEL="0"     | IRDASEL="1" |  |  |
| When UART1CR1 <txe> is "0"</txe>                                                                            |                 |             |  |  |
| From when "1" is written to<br>UART1CR1 <txe> to when the trans-<br/>mitted data is written to TD1BUF</txe> | H level         | L level     |  |  |
| When the STOP, IDLE0 or SLEEP0 mode is active                                                               |                 |             |  |  |

#### Table 11.7 TXD1 Pin Output

#### 12.10.2 Data Receive Operation

Set UART1CR1 <RXE> to "1". When data is received via the RXD1 pin, the received data is transferred to RD1BUF (receive data buffer). At this time, the transmitted data includes a start bit, stop bit(s) and a parity bit if parity addition is specified. When the stop bit(s) are received, data only is extracted and transferred to RD1BUF (receive data buffer). Then the receive buffer full flag UART1SR <RBFL> is set and an INTRXD1 interrupt request is generated. Set the data transfer baud rate using UART1CR1 <BRG>, UART11R2 <RTSEL> and UART1DR.

If an overrun error occurs when data is received, the data is not transferred to RD1BUF (receive data buffer) but discarded; data in the RD1BUF is not affected.

## Page: 204 / 278

## 12.11 Transmit/Receive Operation

#### 12.11.1 Parity Error

When the parity determined using the receive data bits differs from the received parity bit, the parity error flag UART1SR <PERR> is set to "1". At this time, an INTRXD1 interrupt request is generated.

If UART1SR <PERR> is "1" when UART1SR is read, UART1SR <PERR> will be cleared to "0" when RD1BUF is read subsequently. (The RD1BUF read value becomes undefined.)

If UART1SR <PERR> is set to "1" after UART1SR is read, UART1SR <PERR> will not be cleared to "0" when RD1BUF is read subsequently. In this case, UART1SR <PERR> will be cleared to "0" when UART1SR is read again and RD1BUF is read.

| RXD1 pin input        | Start Bit0 Bit1 Bit2 Bit3 Bit4 Bit5 Bit6 Bit7 Parity Stop |                  |                                                |
|-----------------------|-----------------------------------------------------------|------------------|------------------------------------------------|
| UART1SR <perr></perr> |                                                           |                  | PERR is cleared to "0"                         |
| INTRXD1 interrupt re  | equest                                                    |                  | when RD1BUF<br>is read after reading PERR="1". |
| Reading of UART1S     | R                                                         |                  |                                                |
| Reading of RD1BUF     |                                                           | $\checkmark$     | [                                              |
| RD1BUF                |                                                           | Indeterminate    | ¢                                              |
|                       |                                                           | Data             | ↓<br>reading                                   |
| RXD1 pin input        | Start Bit0 Bit1 Bit2 Bit3 Bit4 Bit5 Bit6 Bit7 Parity Stop |                  |                                                |
| UART1SR <perr></perr> | o                                                         | Not cleare       | d PERR is cleared to "0"                       |
| INTRXD1 interrupt re  | equest                                                    |                  | when RD1BUF<br>is read after reading PERR="1". |
| Reading of UART1S     | R                                                         |                  | ↓<br>                                          |
| Reading of RD1BUF     |                                                           |                  |                                                |
| RD1BUF                |                                                           | Vindeterminate Q |                                                |
|                       |                                                           | Data reading     | g Data reading                                 |

#### Figure 12.9 Occurrence of Parity Error

## 12.11.2 Framing Error

If the internal and external baud rates differ or "0" is sampled as the stop bit of received data due to the influence of noise on the RXD1 pin, the framing error flag UART1SR <FERR> is set to "1". At this

#### Page: 205 / 278

time, an INTRXD1 interrupt request is generated.

If UART1SR <FERR> is "1" when UART1SR is read, UART1SR <FERR> will be cleared to "0" when RD1BUF is read subsequently.

If UART1SR <FERR> is set to "1" after UART1SR is read, UART1SR <FERR> will not be cleared to "0" when RD1BUF is read subsequently. In this case, UART1SR <FERR> will be cleared to "0" when UART1SR is read again and RD1BUF is read.

| A falling edge is<br>detected |                                                                          |                                                                          |
|-------------------------------|--------------------------------------------------------------------------|--------------------------------------------------------------------------|
| RXD1 pin input                | Bit2 Bit3 Bit4 Bit5 Bit6 Bit7 Stop                                       |                                                                          |
| Sampling                      |                                                                          | erated if "0" is received<br>ng of the stop bit.                         |
| UART1SR <ferr></ferr>         |                                                                          |                                                                          |
| INTRXD1 interrupt request     | I                                                                        | FERR is cleared to "0"<br>when RD18UF<br>is read after reading FERR="1". |
| Reading of UART1SR            |                                                                          |                                                                          |
| Reading of RD1BUF             |                                                                          |                                                                          |
| RD1BUF                        | VInde termina                                                            | te O                                                                     |
|                               |                                                                          | Data reading                                                             |
|                               | e external baud rate is slower than the inte                             |                                                                          |
| A falling edge is<br>detected |                                                                          | A falling edge is<br>detected                                            |
| RXD1 pin input                |                                                                          | t/Bit0 Bit1 Bit2 Bit3 Bit4 Bit5 Bit6 Bit7 Stop                           |
| Sampling                      | it1 Bit2 Bit3 Bit4 Bit5 Bit6 Bit7 St                                     | op Start Bit0 Bit1 Bit2 Bit3 Bit4 Bit5                                   |
| UART1SR <ferr></ferr>         | FERR is generated if "0" is received<br>in the sampling of the stop bit. |                                                                          |
| INTRXD1 interrupt request     |                                                                          | FERR is cleared to "0"<br>when RD0BUF<br>is read after reading FERR="1". |
| Reading of UART1SR            |                                                                          | ↓<br>┃                                                                   |
| Reading of RD1BUF             |                                                                          |                                                                          |
| RD1BUF                        |                                                                          | Indeterminate O                                                          |
|                               |                                                                          | Data reading                                                             |
| When the                      | e external baud rate is faster than the inte                             | ÷                                                                        |
|                               |                                                                          |                                                                          |
| I                             | Figure 12.10 Occurrence of Fra                                           | aming Error                                                              |

## 12.11.3 Overrun Error

If receiving of all data bits is completed before the previous received data is read from RD1BUF, the overrun error flag UART1SR <OERR> is set to "1" and an INTRXD1 interrupt request is generated. The data received at the occurrence of the overrun error is discarded and the previous received data is maintained. Subsequently, if data is received while UART1SR <OERR> is still "1", no INTRXD1 interrupt request is generated, and the received data is discarded. (Figure 12.11)





Note that parity or framing errors in the discarded received data cannot be detected. (These error flags are not set.) That is to say, if these errors are detected together with an overrun error during the reading of UART1SR, they have occurred in the previous received data (the data stored in RD1BUF). (Figure 12.12)

If UARTISR <OERR> is "1" when UARTISR is read, UARTISR <OERR> will be cleared to "0" whenRD1BUF is read subsequently. (Figure 12.13)

If UART1SR <OERR> is set to "1" after UART1SR is read, UART1SR <OERR> will not be cleared to "0" when RD1BUF is read subsequently. In this case, UART1SR <OERR> will be cleared to "0" when UART1SR is read again and RD1BUF is read. (Figure 12.13)

## Page: 207 / 278

## 汉芝电子股份有限公司

#### iMQ Technology Inc. No. : TDDS01-M6812-EN Name : MQ6812/MQ6821/MQ6822 Datasheet Version: V1.1 Data A Data B Data C Data D ℯ Bit0 arity Stor Start Bit0 Start Bit0 Stor Star Bit 0 arity Stop RXD1 pin input Stop 2 ¥ A parity error occurs The parity is OK. The flag is not set even if UART1SR<FERR> a framing error occurs. The flag is set. UART0SR<PERR> UART11SR<RBFL> UART1SR<OERR> No interrupt request An interrupt request An interrupt request INTRXD1 interrupt request is generated. is generated. is generated. RD1BUF Data A The contents of data D are discarded and those of The contents of data B are discarded The contents of data C are discarded and those of data A are maintained. and those of data A are maintained. data A are maintained. When a parity error occurs in the first received data and a framing error occurs in the second data Data A Data B Data C Data D Bit0 BitO Bit0 arity Bit0 Stop Stop ParityStop Start Stop Start arity Start arity RXD1 pin input ų )) 1 T, The parity is OK. A parity error occurs. The error flag is not set UART1SR<PERR> together with an overrun error. UART1SR<RBFL> UART1SR<OERR> An interrupt request An interrupt request No interrupt request is generated. INTRXD1 interrupt request is generated. is generated. RD1BUF Data A The contents of data B are discarded The contents of data C are The contents of data D are and those of data A are maintained. discarded and those of data A are maintained. discarded and those of data A are maintained.

When a parity error occurs in the second received data

#### Figure 12.12 Framing/Parity Error Flags When an Overrun Error Occurs

## 汉芝电子股份有限公司





#### Figure 12.13 Clearance of Overrun Error Flag

#### 12.11.4 Recevie Data Buffer Full

Loading the received data in RD1BUF sets UART1SR <RBFL> to "1".

If UART1SR <RBFL> is "1" when UART1SR is read, UART1SR <RBFL> will be cleared to "0" when RD1BUF is read subsequently.

If UART1SR <RBFL> is set to "1" after UART1SR is read, UART1SR <RBFL> will not be cleared to "0" when RD1BUF is read subsequently. In this case, UART1SR <RBFL> will be cleared to "0" when UART1SR is read again and RD1BUF is read.

## Page: 209/ 278

#### 汉芝电子股份有限公司 iMQ Technology Inc. No. : TDDS01-M6812-EN Name : MQ6812/MQ6821/MQ6822 Datasheet Version: V1.1 Data A Data B Bit1 Bit0 Bit7 Bit0 Bit7 Stop Ston Start Bit1 RXD1 pin input UART1SR<RBFL> RBFL is cleared to "0" when RD1BUF is read after reading RBFL="1". INTRXD1 interrupt request Reading of UART1SR Reading of RD1BUF RD1BUF Data A Data B Ċ Reading of data A Reading of data B

Figure 12.14 Occurrence of Receive Data Buffer Full

## 12.11.5 Transmit Busy Flag

If transmission is completed with no waiting data in TD1BUF (when UART1SR <TBFL>="0"), UART1SR <TBSY> is cleared to "0". When transmission is restarted after data is written into TD1BUF, UART1SR <TBSY> is set to "1". At this time, an INTTXD1 interrupt request is generated.



#### Figure 12.15 Transmit Busy Flag and Occurrence of Transmit Buffer Full

## Page: 210/ 278

## 12.11.6 Transmit Buffer Full

When TD1BUF has no data, or when data in TD1BUF is transferred to the transmit shift register and transmission is tarted, UART1SR <TBFL> is cleared to "0". At this time, an INTTXD1 interrupt request is generated.

Writing data into TD1BUF sets UART1SR <TBFL> to "1".





## 12.12 Receiving Process

Figure 12.17 shows an example of the receiving process. Details of flag judgments in the processing are shown in Table 12.8 and Table 12.9.

If any framing error or parity error is detected, the received data has erroneous value(s). Execute the error handling, for example, by discarding the received data read from RD1BUF and receiving the data again.

If any overrun error is detected, the receiving of one or more pieces of data is unfinished. It is impossible to determine the number of pieces of data that could not be received. Execute the error handling, for example, by receiving data again from the beginning of the transfer. Basically, an overrun error occurs when the internal software processing cannot follow the data transfer speed. It is recommended to slow the transfer baud rate or modify the software to execute flow control.

## Page: 211/ 278



#### Figure 12.17 Example of Receiving Process

Note): If multiple interrupts are used in the INTRXD1 interrupt subroutine, the interrupt should be enabled after reading UART1SR and RD1BUF.

| RBFL | FERR/PERR | OERR | State                                                                                                                                                |
|------|-----------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | -         | 0    | Data has not been received yet.                                                                                                                      |
|      |           |      | Some pieces of data could not be received during the previ-<br>ous data receiving process                                                            |
| 0    | -         | 1    | (Receiving of next data is completed in the period from<br>when UART1SR is read to when RD1BUF is read in the pre-<br>vious data receiving process.) |
| 1    | 0         | 0    | Receiving has been completed properly.                                                                                                               |
| 1    | 0         | 1    | Receiving has been completed properly, but some pieces<br>of data could not be received.                                                             |
| 1    | 1         | 0    | Received data has erroneous value(s).                                                                                                                |
| 1    | 1         | 1    | Received data has erroneous value(s) and some pieces of data could not be received.                                                                  |

Table 12.8 Flag Judgments When No Receive Interrupt Is Used

Page: 212/ 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| FERR/PERR | OERR | State                                                                                    |
|-----------|------|------------------------------------------------------------------------------------------|
| 0         | 0    | Receiving has been completed properly.                                                   |
| 0         | 1    | Receiving has been completed properly, but some pieces<br>of data could not be received. |
| 1         | 0    | Received data has erroneous value(s).                                                    |
| 1         | 1    | Received data has erroneous value(s) and some pieces of data could not be received.      |

Table 12.9 Flag Judgments When a Receive Interrupt Is Used

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 13. Flash Memory

MQ6812/MQ6821 has flash memory of 16K x 8 bytes. A write and erase to be performed on flash memory can be controlled in the MCU mode, where the flash memory is accessed by the CPU control, and the flash memory can be executed the erasing and writing without affecting the operations of a running application. Therefore, this mode is used for software debugging and firmware change after shipment of the MQ6812/MQ6821.

In MCU mode, flash memory control registers (FLSCR1 and FLSCR2) are used to control the flash memory. This chapter describes how to access the flash memory using the MCU mode.

## 13.1 Flash Memory Control

The flash memory is controlled by the flash memory control register 1 (FLSCR1), flash memory control register 2 (FLSCR2), and flash memory standby control register (FLSSTB).

| FLSCR1<br>(0x0FD0) | 7 6 |       | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------|-----|-------|---|---|---|---|---|---|
| Bit Symbol         |     | FLSMD |   | - | - | - | - | - |
| Read/Write         |     | R/W   |   | R | R | R | R | R |
| After reset        | 0   | 0     | 0 | 0 |   | 0 | 0 | 0 |

Flash Memory Control Register 1

|       |                                                     | 010: Disable command sequence and toggle execution |
|-------|-----------------------------------------------------|----------------------------------------------------|
| FLSMD | Flash memory command sequence<br>and toggle control | 101: Enable command sequence and toggle execution  |
|       |                                                     | Others: Reserved                                   |

Note 1: It is prohibited to make a setting in "Reserved".

Note 2: The flash memory control register 1 has a double-buffer structure comprised of the register FLSCR1 and a shift register. Writing "0xD5" to the register FLSCR2 allows a register setting to be reflected and take effect in the shift register. This means that a register setting value does not take effect until "0xD5" is written to the register FLSCR2. The value of the shift register can be checked by reading the register FLSCRM.

Note 3: FLSMD must be set to either "0y010" or "0y101".

#### Flash Memory Control Register 2

| FLSCR2<br>(0x0FD1) | 7 | 6     | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|--------------------|---|-------|---|---|---|---|---|---|--|--|--|
| Bit Symbol         |   | CRIEN |   |   |   |   |   |   |  |  |  |
| Read/Write         |   | Ŵ     |   |   |   |   |   |   |  |  |  |
| After reset        | 0 | 0     | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |

| CRIEN |                                          | 0xD5: Enable a change in the FLSCR1 setting |
|-------|------------------------------------------|---------------------------------------------|
| CR1EN | FLSCR1 register enable / disable control | Others: Reserved                            |

## Page: 214/ 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

Note): If "0xD5" is set on FLSCR2<CR1EN> with FLSCR1<FLSMD> set to "101", the flash memory goes into an active state, and MCU consumes the same amount of current as it does during a read.

| FLSCRM<br>(0x0FD1) | 7 | 6 | 5      | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |
|--------------------|---|---|--------|---|---|---|---|---|--|--|--|--|--|--|
| Bit Symbol         | - | - | FLSMDM | - | - | - | - | - |  |  |  |  |  |  |
| Read/Write         | R | R | R      | R | R | R | R | R |  |  |  |  |  |  |
| After reset        | 0 | 0 | 0      | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |

#### Flash Memory Control Register 1 Monitor

| FLSMDM | Monitoring of FLSCR1 <flsmd> status</flsmd> |
|--------|---------------------------------------------|
|        | 5                                           |

0: FLSCR1 <FLSMD>="101" setting disabled 1: FLSCR1 <FLSMD>="101" setting enabled

Note 1: FLSCRM is the register that checks the value of the shift register of the flash memory control register 1. Note 2: FLSMDM turns into "1" only if FLSMD="101" becomes effective.

Note 3: If an instruction to read FLSCRM is executed, "0" is read from bits 7~6 and Bit 4~0..

## 13.2 Flash Memory Functions

#### 13.2.1 Flash Memory Command Sequence and Toggle Control (FLSCR1 <FLSMD>)

To prevent inadvertent writes to the flash memory due to program error or microcontroller malfunction, the execution of the flash memory command sequence and the toggle operation can be disabled (the flash memory can be write protected) by making an appropriate control register setting (write protect). To enable the execution of the command sequence and the toggle operation, set FLSCR1<FLSMD> to "0y101", and then set "0xD5" on FLSCR2<CR1EN>. To disable the execution of the command sequence, set FLSCR1<FLSMD> to "0y010", and then set "0xD5" on FLSCR2<CR1EN>. If the command sequence or the toggle operation is executed with the execution of the command sequence or toggle operation set to "disable", the executed command sequence or toggle operation takes no effect. After a reset, FLSCR1<FLSMD> is initialized to "0y010" to disable the execution of the command sequence. FLSCR1<FLSMD> is initialized to "0y010" except when a write or erase is to be performed on the flash memory.

Note 1): If "0xD5" is set on FLSCR2<CR1EN> with FLSCR1<FLSMD> set to "101", the flash memory goes into an active state, and MCU consumes the same amount of current as it does during a read.

Note 2]: If FLSCR1<FLSMD> is set to "disable", subsequent commands (write instructions) generated are rejected but a command sequence being executed is not initialized.

If you want to set FLSCR1<FLSMD> to "disable", you must finish all command sequences and verify that the flash memory is ready to be read.

#### Page: 215/ 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

## 13.3 Command Sequence

In MCU mode, the command sequence consists of six commands (JEDEC compatible), as shown in Table 13.1.

| Comn | nand Sequence                                              | 1 <sup>st</sup> Bus Writer<br>Cycle |      | 2 <sup>nd</sup> Bus Writer Cycle |      | 3 <sup>rd</sup> Bus Writer Cycle |      | 4 <sup>th</sup> Bus Writer Cycle |               | 5 <sup>th</sup> Bus Writer Cycle |      | 6 <sup>th</sup> Bus Writer<br>Cycle |      |
|------|------------------------------------------------------------|-------------------------------------|------|----------------------------------|------|----------------------------------|------|----------------------------------|---------------|----------------------------------|------|-------------------------------------|------|
|      | ·                                                          | Add                                 | Data | Add                              | Data | Add                              | Data | Add                              | Data          | Add                              | Data | Add                                 | Data |
| 1    | Byte Program                                               | 0x#555                              | 0xAA | 0x#AAA                           | 0x55 | 0x#555                           | 0xA0 | BA<br>(注 1)                      | Data<br>(注 1) | 0xF566                           | 0xFF | -                                   |      |
| 2    | Sector<br>Erase(Partial<br>erase in units<br>of 128 bytes) | 0x#555                              | 0xAA | 0x#AAA                           | 0x55 | 0x#555                           | 0x80 | 0x#555                           | 0xAA          | 0x#AAA                           | 0x55 | SA<br>(note 2)                      | 0x20 |
| 3    | Sector<br>Erase(Partial<br>erase in units<br>of 1K bytes)  | 0x#555                              | 0xAA | 0x#AAA                           | 0x55 | 0x#555                           | 0x80 | 0x#555                           | 0xAA          | 0x#AAA                           | 0x55 | SA<br>(note 2)                      | 0x30 |
| 4    | Chip Erase<br>(All erase)                                  | 0x#555                              | 0xAA | 0x#AAA                           | 0x55 | 0x#555                           | 0x80 | 0x#555                           | 0xAA          | 0x#AAA                           | 0x55 | 0x#555                              | 0x10 |

#### Table 13.1 Command Sequence

Note 1: Specify the address and data to be written (Refer to Table 13-2 about BA).

Note 2: The area to be erased is specified with the upper 5 bits of the address (Refer to Table 13-3 about SA).

Note 3: Do not start the STOP, IDLE0, IDLE1, IDLE2, SLEEP1 or SLEEP0 mode while a command sequence is being executed or a task specified in a command sequence is being executed (write, erase or ID entry).

Note 4: # ; 0x8 through 0xF should be specified as the upper 4bits of the address. Usually, it is recommended that 0xF is specified. Note 5: XXX ; Don't care

#### 13.3.1 Byte Program

This command writes the flash memory in units of one byte. The address and data to be written are specified in the 4th bus write cycle. The range of addresses that can be specified is shown in Table 13-2. For example, to write data to 0xC000 in the data area, set FLSCR1<FAREA> to "0y00", set "0xD5" on FLSCR2<CR1EN>, and then specify 0xC000 as an address in the 4th bus write cycle. The time needed to write each byte is 40 µs maximum. The next command sequence cannot be executed if an ongoing write operation is not completed. To check the completion of the write operation, perform read operations twice on the same address in the flash memory, and perform polling until the same data is read from the flash memory. During the write operation, bit 6 is reversed each time a read is performed.

Note 1: To rewrite data to addresses in the flash memory where data (including 0xFF) is already written, make sure that you erase the existing data by performing a sector erase or chip erase before writing data.

#### Page: 216 / 278

# 13.3.2 Sector Erase (128 Byte Partial Erase)

This command erases the flash memory in units of 128 bytes. The flash memory area to be erased is specified by the upper 5 bits of the 6th bus write cycle address. The range of addresses that can be specified is shown in Table 13-3. For example, to erase 128 byte from 0xE000 through 0xE07F in the code area, set FLSCR1<FAREA> to "101", set "0xD5" on FLSCR2<CR1EN>, and then specify either 0xE000 or 0xE07F as the 6th bus write cycle.

The time needed to erase 128 bytes is 5 ms maximum. The next command sequence cannot be executed if an ongoing erase operation is not completed. During the operation, CPU would enter IDEL 1/2 mode until the erase operation.

Data in the erased area is 0xFF.

# 13.3.3 Entry Product ID mode

This command can enter product ID mode. In product ID mode, excute the read instruction, can read out the information(Vendor ID,Flash ID, Security status). erases the entire flash memory.

| Address | Meaning         | Value                                                                                         |
|---------|-----------------|-----------------------------------------------------------------------------------------------|
| 0xF000  | Vendor ID       | 0x68                                                                                          |
| 0xF001  | Flash ID        | 0x12                                                                                          |
| 0xFF7F  | Security Status | 0xFF: Flash data security function disable<br>Excpt 0XFF: Flash data security function enable |

Table 13.2 The meaning of address in product ID mode

# 13.3.4 Out of Product ID mode

his command can exit product ID mode.

# 13.4 Access to the Flash Memory Area

A read or a program fetch cannot be performed on the whole of the flash memory area if data is being written to the flash memory, if data in flash memory is being erased or if a security setting is being made in the flash memory. When performing these operation on the flash memory area, the flash memory cannot be directly accessed by using a program in the flash memory. During the operation, CPU would enter IDEL 1/2 mode until the erase operation.

Data can be written to and read from the flash memory area in units of one byte. Data in the flash memory can be erased in units of 128 bytes( one sector).

# Page: 217/ 278

Note 1: To allow a program to resume control on the flash memory area that is rewritten, it is recommended that you let the program jump (return) after verifying that the program has been written properly.

Note 2: Do not reset the MCU (including a reset generated due to internal factors) when data is being written to the flash memory, data is being erased from the flash memory or the security command is being executed. If a reset occurs, there is the possibility that data in the flash memory may be rewritten to an unexpected value.

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 14.Serial Bus Interface(SBI)/ I2C

MQ6812/MQ6821 contains 1 channels of serial bus interface(SBI). The serial bus interface supports serial communication conforming to the I2C bus standards. It has clock synchronization and arbitration functions, and supports the multi-master in which multiple masters are connected on a bus. It also supports the unique free data format.

# 14.1 Communication Format

#### 14.1.1 I2C bus

The I2C bus is connected to devices via the SDA0 and SCL0 pins and can communicate with multiple devices.



Figure 14.1 Device Connections

Communications are implemented between a master and slave.

The master transmits the start condition, the slave addresses, the direction bit and the stop condition to the slave(s) connected to the bus, and transmits and receives data.

The slave detects these conditions transmitted from the master by the hardware, and transmits and receives data.

The data format of the I2C bus that can communicate via the serial bus interface is shown in Figure 14-2.

The serial bus interface does not support the following functions among those specified by the I2C bus standards:

- 1. Start byte
- 2. 10-bit addressing
- 3. SDA and SCL pins falling edge slope control

# Page: 219/ 278

# 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

#### (a) Addressing format



(b) Addressing format (with restart)



S : Start condition R/W : Direction bit ACK : Acknowledge bit

P : Stop condition



#### 14.1.2 Free data format

The free data format is for communication between a master and slave. In the free data format, the slave address and the direction bit are processed as data.



Figure 14.3 Free Data Format

#### Page: 220 / 278

# 14.2 Configuration



Figure 14.4 Serial Bus Interface0 (SBI0)

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 14.3 Control

The following registers are used to control the serial bus interface and monitor the operation status.

- Serial bus interface control register 1 ( (SBIOCR1)
- Serial bus interface control register 2 (SBI0CR2)
- Serial bus interface status register 2 (SBI0SR2)
- Serial bus interface data buffer register (SBIOBR)
- I2C bus address register (I2C0AR)

#### Other related register

-Low power consumption register1 (POFFCR1)

Set POOFFCR1<SBI0EN> to"1", before enable SBI/I2C function, unless the SBI/I2C setting is invalid.

-Port P2 Output Control Registe (P2OUTCR)

Set P2OUTCR3 and P2OUTCR4 to"1", before enable SBI/I2C function

- Port P2 Output Latch Register (P2DR) Set P2DR to"0" before enable SBI/I2C function, unless the SBI/I2C function would operate unexpectedly.

In addition, the serial bus interface has low power consumption registers that save power when the serial bus interface is not being used.

| POFFCR1<br>(0x0F75) | 7 | 6 | 5 | 4      | 3 | 2 | 1       | 0 |
|---------------------|---|---|---|--------|---|---|---------|---|
| Bit Symbol          | - | - | - | SBIOEN | - | - | UART1EN | - |
| Read/Write          | R | R | R | R/W    | R | R | R/W     | R |
| After reset         | 0 | 0 | 0 | 0      | 0 | 0 | 0       | 0 |

#### Low power consumption register1

| SBIOEN  | I <sup>2</sup> C0 control | 0:Disable<br>1:Enable |
|---------|---------------------------|-----------------------|
|         |                           | 0:Disable             |
| UART1EN | UART1 control             | 1:Enable              |

Note: When SBI0EN is cleared to "0", the clock supply to the serial bus interface is stopped. At this time, the data written to the serial bus interface control registers is invalid. When the serial bus interface is used, set SBI0EN to "1" and then write the data to the serial bus interface control registers.

# Page: 222/ 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

#### Serial bus interface control register 1

| SBIOCR1<br>(0x0022) | 7   | 6   | 5   | 4   | 3     | 2   | 1   | 0   |
|---------------------|-----|-----|-----|-----|-------|-----|-----|-----|
| Bit Symbol          |     | BC  |     | ACK | NOACK |     | SCK |     |
| Read/Write          | R/W | R/W | R/W | R/W | R/W   | R/W | R/W | R/W |
| After reset         | 0   | 0   | 0   | 0   | 0     | 0   | 0   | 0   |

| ВС    | Number of data bits                                      | вс    | ACK:                                                                                                                                      | =0             |                    | ACK                                                                                                                                                | = 1                 |
|-------|----------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
|       |                                                          |       | Number of clocks for data transfer                                                                                                        | Number         | r of data bits     | Number of clocks for data transfer                                                                                                                 | Number of data bits |
|       |                                                          | 000   | 8                                                                                                                                         |                | 8                  | 9                                                                                                                                                  | 8                   |
|       |                                                          | 001   | 1                                                                                                                                         |                | 1                  | 2                                                                                                                                                  | 1                   |
|       |                                                          | 010   | 2                                                                                                                                         |                | 2                  | 3                                                                                                                                                  | 2                   |
|       |                                                          | 011   | 3                                                                                                                                         |                | 3                  | 4                                                                                                                                                  | 3                   |
|       |                                                          | 100   | 4                                                                                                                                         |                | 4                  | 5                                                                                                                                                  | 4                   |
|       |                                                          | 101   | 5                                                                                                                                         |                | 5                  | 6                                                                                                                                                  | 5                   |
|       |                                                          | 110   | 6                                                                                                                                         |                | 6                  | 7                                                                                                                                                  | 6                   |
|       |                                                          | 111   | 7                                                                                                                                         |                | 7                  | 8                                                                                                                                                  | 7                   |
| АСК   | Generation and                                           | ACK   | Mast                                                                                                                                      | er mode        |                    |                                                                                                                                                    | e mode              |
|       | counting<br>of the clocks for an<br>acknowledge signal   | 0:    | Not generating the c<br>acknowledge signal.<br>request when the da<br>transfer is finished<br>(non-acknowledgem                           | Generate<br>ta | e an interrupt     | the data transfer is                                                                                                                               |                     |
|       |                                                          | 1:    | Generate the clocks for an acknowledge<br>signal and an interrupt request when the<br>data transfer is finished<br>(acknowledgement mode) |                |                    | Count the clocks for an acknowledge<br>signal and generate an interrupt<br>request when the data<br>transfer is finished<br>(acknowledgement mode) |                     |
|       | Enables/disables the                                     | NOACK | Mast                                                                                                                                      | er mode        |                    |                                                                                                                                                    | e mode              |
| NOACK | slave address match<br>detection and the<br>GENERAL CALL | 0:    | Dor                                                                                                                                       | n't Care       |                    | Enable the slave a detection and the detection                                                                                                     |                     |
|       | detection                                                | 1:    | Dor                                                                                                                                       | n't Care       |                    | Disable the slave a detection and the detection                                                                                                    |                     |
| SCK   | HIGH and LOW periods                                     | SCK   | tнідн(m/fcgck<br>m                                                                                                                        | x)             | t₋ow(n/fcgck)<br>n | - fscl@fcgd                                                                                                                                        | ck=8MHz             |
|       | of the serial clock in                                   | 000   | 9                                                                                                                                         |                | 12                 | 381                                                                                                                                                | KHz                 |
|       | the master mode<br>Time before the                       | 001   | 11                                                                                                                                        |                | 14                 | 320                                                                                                                                                | NKHz                |
|       | release                                                  | 010   | 15                                                                                                                                        | 15 18 2421     |                    | YKHz                                                                                                                                               |                     |
|       | of the SCL pin in the<br>slave mode                      | 011   | 23                                                                                                                                        | 23 26 163KHz   |                    | YKHz                                                                                                                                               |                     |
|       |                                                          | 100   | 39                                                                                                                                        |                | 42                 | 991                                                                                                                                                | KHz                 |
|       |                                                          | 101   | 71                                                                                                                                        |                | 74                 | 551                                                                                                                                                | KHz                 |
|       |                                                          | 110   | 135                                                                                                                                       |                | 138                | 291                                                                                                                                                | KHz                 |
|       |                                                          | 111   | 263                                                                                                                                       |                | 266                | 15                                                                                                                                                 | KHz                 |

Note 1: fcgck = Gear clock [Hz], fs = Low-frequency clock [Hz] °

Note2: Don't change the contents of the registers when the start condition is generated, the stop condition is generated or the data transfer is in progress. Write data to the registers before the start condition is generated or during the period from when an interrupt request is generated for stopping the data transfer until it is released.

Note 3: After a software reset is generated, all the bits of SBIOCR2 register except SBIOCR2<SBIM> and the SBIOCR1, I2COAR and SBIOSR2 registers are initialized.

Note 4: When the operation is switched to STOP, IDLE0 or SLOW mode, the SBIOCR2 register, except SBIOCR2<SBIM>, and the SBIOCR1, I2COAR and SBIODBR registers are initialized.

Note 5: When fcgck is 4MHz, SCK should be not set to 0y000, 0y001 or 0y010 because it is not possible to satisfy the bus specification of fast mode.

#### Serial bus interface control register2

| SBIOCR2<br>(0x0023) | 7   | 6   | 5  | 4   | 3    | 2 | 1  | 0   |
|---------------------|-----|-----|----|-----|------|---|----|-----|
| Bit Symbol          | MST | TRX | BB | PIN | SBIM | - | SW | RST |
| Read/Write          | W   | W   | W  | W   | W    | R | W  | W   |
| After reset         | 0   | 0   | 0  | 1   | 0    | 0 | 0  | 0   |

| MST   | Master/slave selection                       | 0:Slave<br>1:Master                                                                                                                 |
|-------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| TRX   | Transmitter/receiver selection               | 0:Receiver<br>1:Transmitter                                                                                                         |
| BB    | Start/stop generation                        | 0:Generate the stop condition(when MST 	TRX and<br>PIN are"1")<br>1: Generate the start condition (when MST 	TRX and<br>PIN are"1") |
| PIN   | Cancel interrupt service request             | 0:- (cannot clear this bit by software)<br>1: Cancel interrupt service request                                                      |
| SBIM  | Serial bus interface operation mode register | 0: Port mode<br>1:Serial bus interface mode                                                                                         |
| SWRST | Software reset start bit                     | The software reset starts by first writing "10" and next writing"01"                                                                |

Note 1: When SBIOCR2<SBIM> is "0", no value can be written to SBIOCR2 except SBIOCR2<SBIM>. Before writing values to SBIOCR2, write "1" to SBIOCR2<SBIM> to activate the serial bus interface mode.

Note 2: Don't change the contents of the registers, except SBIOCR2<SWRST>, when the start condition is generated, the stop condition is generated or the data transfer is in progress. Write data to the registers before the start condition is generated or during the period from when an interrupt request is generated for stopping the data transfer until it is released.

Note 3: Make sure that the port is in a high state before switching the port mode to the serial bus interface mode. Make sure that the bus is free before switching the serial bus interface mode to the port mode.

Note 4: SBIOCR2 is a write-only register, and must not be accessed by using a read-modify-write instruction, such as a bit operation. Note 5: After a software reset is generated, all the bits of SBIOCR2 register except SBIOCR2<SBIM> and the SBIOCR1, I2COAR and SBIOSR2 registers are initialized.

Note 6: When the operation is switched to STOP, IDLE0 or SLOW mode, the SBIOCR2 register, except SBIOCR2<SBIM>, and the SBIOCR1, I2COAR and SBIODBR registers are initialized.

# Page: 224 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Serial | bus | inte | rface | status | register | ·2 |
|--------|-----|------|-------|--------|----------|----|
|        |     |      |       |        |          |    |

| SBIOSR2<br>(0x0023) | 7   | 6   | 5  | 4   | 3  | 2   | 1   | 0   |
|---------------------|-----|-----|----|-----|----|-----|-----|-----|
| Bit Symbol          | MST | TRX | BB | PIN | AL | AAS | AD0 | LRB |
| Read/Write          | R   | R   | R  | R   | R  | R   | R   | R   |
| After reset         | 0   | 0   | 0  | 1   | 0  | 0   | 0   | *   |

| MST | Master/slave selection status monitor         | 0:Slave<br>1:Master                                             |
|-----|-----------------------------------------------|-----------------------------------------------------------------|
| TRX | Transmitter/receiver selection status monitor | 0:Receiver<br>1:Transmitter                                     |
| BB  | Bus status monitor                            | 0:Bus free<br>1: Bus busy                                       |
| PIN | Interrupt service requests status monitor     | 0:Requesting interrupt service<br>1:Releasing interrupt service |
| AL  | Arbitration lost detection monitor            | 0: -<br>1:Aritration lost detected                              |
| AAS | Slave address match detection monitor         | 0: -<br>1:Detect slave address match or "GENERAL<br>CALL"       |
| AD0 | "GENERAL CALL" detection monitor              | 0: -<br>1: Detect "GENERAL CALL"                                |
| LRB | Last received bit monitor                     | 0: Last received bit is"0"<br>1: Last received bit is"1"        |

Note 1: \* Unstable

Note 2: When SBIOCR2<SBIM> becomes "0", SBIOSR is initialized.

Note 3: After a software reset is generated, all the bits of the SBIOCR2 register except SBIOCR2<SBIM> and the SBIOCR1, I2COAR and SBIOSR2 registers are initialized.

Note 4: When the operation is switched to STOP, IDLE0 or SLOW mode, the SBIOCR2 register, except SBIOCR2<SBIM>, and the SBIOCR1, I2COAR and SBIODBR registers are initialized.

| I2C0AR<br>(0x0024) | 7   | 6                       | 5 | 4  | 3 | 2 | 1 | 0   |
|--------------------|-----|-------------------------|---|----|---|---|---|-----|
| Bit Symbol         |     |                         |   | SA |   |   |   | ALS |
| Read/Write         | R/W | R/W R/W R/W R/W R/W R/W |   |    |   |   |   | R/W |
| After reset        | 0   | 0                       | 0 | 0  | 0 | 0 | 0 | 0   |

#### I<sup>2</sup>C bus address register

| SA  | Slave address setting          | Slave address in the slave mode |
|-----|--------------------------------|---------------------------------|
| ALS | Communication format selection | 0: I <sup>2</sup> C bus mode    |
| ALS | Communication format selection | 1: Free data format             |

Note 1: Don't set I2C0AR<SA> to "0x00". If it is set to "0x00", the slave address is deemed to be matched when the I2C bus standard start byte ("0x01") is received in the slave mode.

Note 2: Don't change the contents of the registers when the start condition is generated, the stop condition is generated or the data transfer is in progress. Write data to the registers before the start condition is generated or during the period from when an interrupt request is generated for stopping the data transfer until it is released.

Note 3: After a software reset is generated, all the bits of the SBIOCR2 register except SBIOCR2<SBIM> and the SBIOCR1, I2COAR and

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

#### SBIOSR2 registers are initialized.

Note 4: When the operation is switched to STOP, IDLE0 or SLOW mode, the SBIOCR2 register, except SBIOCR2<SBIM>, and the SBIOCR1, I2COAR and SBIODBR registers are initialized.

#### Serial bus interface data buffer register

| SBIODBR<br>(0x0025) | 7   | 6       | 5   | 4   | 3   | 2   | 1   | 0   |  |
|---------------------|-----|---------|-----|-----|-----|-----|-----|-----|--|
| Bit Symbol          |     | SBIODBR |     |     |     |     |     |     |  |
| Read/Write          | R/W | R/W     | R/W | R/W | R/W | R/W | R/W | R/W |  |
| After reset         | 0   | 0       | 0   | 0   | 0   | 0   | 0   | 0   |  |

#### Note 1 : Write the transmit data beginning with the most significant bit (bit 7).

Note 2: SBIODBR has individual writing and reading buffers, and written data cannot be read out. Therefore, SBIODBR must not be accessed by using a read-modify-write instruction, such as a bit operation.

Note 3:: Don't change the contents of the registers when the start condition is generated, the stop condition is generated or the data transfer is in progress. Write data to the registers before the start condition is generated or during the period from when an interrupt request is generated for stopping the data transfer until it is released.

Note 4: To set SBIOCR2<PIN> to "I" by writing the dummy data to SBIODBR, write 0x00. Writing any data other than 0x00 causes an improper value in the subsequently received data.

Note 5: When the operation is switched to STOP, IDLE0 or SLOW mode, the SBI0CR2 register, except SBI0CR2<SBIM>, and the SBIOCR1, I2COAR and SBIODBR registers are initialized.

# 14.4 Functions

# 14.4.1 Low power consumption function

The serial bus interface has a low power consumption register (POFFCR1) that saves power when the serial bus interface is not being used.

Setting POFFCR1<SBI0EN> to "0" disables the basic clock supply to the serial bus interface to save power. Note that this makes the serial bus interface unusable. Setting POFFCR1<SBI0EN> to "1" enables the basic clock supply to the serial bus interface and makes external interrupts usable.

After reset, POFFCR1<SBI0EN> is initialized to "0", and this makes the serial bus interface unusable. When using the serial bus interface for the first time, be sure to set POFFCR1<SBI0EN> to "1" in the initial setting of the program (before the serial bus interface control registers are operated).

Do not change POFFCR1<SBI0EN> to "0" during the serial bus interface operation, otherwise serial bus interface may operate unexpectedly.

#### 14.4.2 Selecting the slave address match detection and the GENERAL CALL detection

SBIOCR1<NOACK> enables and disables the slave address match detection and the GENERAL CALL detection in the slave mode. Clearing SBI0CR1<NOACK> to "0" enables the slave address match detection and the GENERAL CALL detection.

Setting SBIOCR1<NOACK> to "1" disables the subsequent slave address match and GENERAL CALL detections. The slave addresses and "GENERAL CALL" sent from the master are ignored. No acknowledgement is returned and no interrupt request is generated.

In the master mode, SBI0CR1<NOACK> is ignored and has no influence on the operation.

Note: If SBIOCR1<NOACK> is cleared to "0" during data transfer in the slave mode, it remains at "1" and returns an acknowledge signal of data transfer.

# 14.4.3 Selecting the number of clocks for data transfer and selecting the acknowledgement or non-acknowledgement mode

1-word data transfer consists of data and an acknowledge signal. When the data transfer is finished, an interrupt request is generated.

SBI0CR1<BC> is used to select the number of bits of data to be transmitted/received subsequently. The acknowledgment mode is activated by setting SBI0CR1<ACK> to "1".

# Page: 227 / 278

| 汉芝电子股份有限公司<br>iMO Technology Inc. |                                       |                |
|-----------------------------------|---------------------------------------|----------------|
| 55                                | Name : MQ6812/MQ6821/MQ6822 Datasheet | Version : V1.1 |

The master device generates the clocks for an acknowledge signal and outputs an acknowledge signal in the receiver mode. The slave device counts the clocks for an acknowledge signal and outputs an acknowledge signal in the receiver mode.

The non-acknowledgment mode is activated by setting SBI0CR1<ACK> to "0". The master device does not generate the clocks for an acknowledge signal. The slave device does not count the clocks for an acknowledge signal.

#### 14.4.3.1 Number of clock for data transfer

The number of clocks for data transfer is set by using SBI0CR1<BC> and SBI0CR1<ACK>. The acknowledgment mode is activated by setting SBI0CR1<ACK> to "1".

In the acknowledgment mode, the master device generates the clocks that correspond to the number of data bits, generates the clocks for an acknowledge signal, and generates an interrupt request. The slave device counts the clocks that correspond to the data bits, counts the clocks for an acknowledge signal, and generates an interrupt request.

The non-acknowledgment mode is activated by setting SBIOCR1<ACK> to "0". In the non-acknowledgment mode, the master device generates the clocks that correspond to the number of data bits, and generates an interrupt request. The slave device counts the clocks that correspond to the data bits, and generates an interrupt request.



#### Figure 14.5 Number of clocks for Data transfer and SBI0CR1<BC> and SBI0CR1<ACK>

The relationship between the number of clocks for data transfer and SBI0CR1<BC> and SBI0CR1<ACK> is shown in Table 14.1

#### Page: 228 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

|     | ACK=0 (Non-acknow                     | edgment mode)       | ACK=1 (Acknowledgment mode)        |                     |  |
|-----|---------------------------------------|---------------------|------------------------------------|---------------------|--|
| BC  | Number of clocks for data<br>transfer | Number of data bits | Number of clocks for data transfer | Number of data bits |  |
| 000 | 8                                     | 8                   | 9                                  | 8                   |  |
| 001 | 1                                     | 1                   | 2                                  | 1                   |  |
| 010 | 2                                     | 2                   | 3                                  | 2                   |  |
| 011 | 3                                     | 3                   | 4                                  | 3                   |  |
| 100 | 4                                     | 4                   | 5                                  | 4                   |  |
| 101 | 5                                     | 5                   | 6                                  | 5                   |  |
| 110 | 6                                     | 6                   | 7                                  | 6                   |  |
| 111 | 7                                     | 7                   | 8                                  | 7                   |  |

# Table 14.1 Relationship between the Number of Clocks for Data Transfer and SBI0CR1<BC> and SBI0CR1<ACK>

BC is cleared to "000" by the start condition. Therefore, the slave address and the direction bit are always transferred in 8-bit units. In other cases, BC keeps the set value.

Note: SBIOCR1<ACK> must be set before transmitting or receiving a slave address. When SBIOCR1<ACK> is cleared, the slave address match detection and the direction bit detection are not executed properly.

#### 14.4.3.2 Output of an acknowledge signal

In the acknowledgment mode, the SDA0 pin changes as follows during the period of the clocks for an acknowledge signal.

#### (a) In the master mode

In the transmitter mode, the SDA0 pin is released to receive an acknowledge signal from the receiver during the period of the clocks for an acknowledge signal. In the receiver mode, the SDA0 pin is pulled down to the low level and an acknowledge signal is generated during the period of the clocks for an acknowledge signal.

#### (b) In the slave mode

When a match between the received slave address and the slave address set to I2C0AR<SA> is detected or when a GENERAL CALL is received, the SDA0 pin is pulled down to the low level and an acknowledge signal is generated during the period of the clocks for an acknowledge signal.

During the data transfer after the slave address match is detected or a "GENERAL CALL" is received in the transmitter mode, the SDA0 pin is released to receive an acknowledge signal from the receiver during the period of the clocks for an acknowledge signal.

In the receiver mode, the SDA0 pin is pulled down to the low level and an acknowledge

#### Page: 229/ 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

signal is generated. Table 19-2 shows the states of the SCLO and SDAO pins in the acknowledgment mode.

Note: In the non-acknowledgment mode, the clocks for an acknowledge signal are not generated or counted, and thus no acknowledge signal is output.

| Mode   | Pin  | Condition                                                                                          | Transmitter                                      | Receiver                                                      |
|--------|------|----------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------------------------------|
| Master | SCL0 | -                                                                                                  | Add the clocks for an acknowl-<br>edge signal.   | Add the clocks for an acknowl-<br>edge signal                 |
|        | SDA0 | -                                                                                                  | Release the pin to receive an acknowledge signal | Output the low level as an ac-<br>knowledge signal to the pin |
| Slave  | SCL0 | -                                                                                                  | Count the clocks for an ac-<br>knowledge signal  | Count the clocks for an ac-<br>knowledge signal               |
|        | 0044 | When the slave address<br>match is detected or a<br>"GENERAL CALL" is re-<br>ceived                | -                                                | Output the low level as an ac-<br>knowledge signal to the pin |
|        | SDA0 | During transfer after the<br>slave address match is<br>detected or a "GENERAL<br>CALL" is received | Release the pin to receive an acknowledge signal | Output the low level as an ac-<br>knowledge signal to the pin |

#### Table 14.2 States of the SCL0 and SDA0 pins in the acknowledgment mode

#### 14.4.4 Serial clock

#### 14.4.4.1 Clock source

SBIOCR1<SCK> is used to set the HIGH and LOW periods of the serial clock to be output in the master mode.

| SCK  | t <sub>HIGH</sub> (m/fcgck) | t <sub>LOW</sub> (n/fcgck) |
|------|-----------------------------|----------------------------|
| SCK  | m                           | n                          |
| 000: | 9                           | 12                         |
| 001: | 11                          | 14                         |
| 010: | 15                          | 18                         |
| 011: | 23                          | 26                         |
| 100: | 39                          | 42                         |
| 101: | 71                          | 74                         |
| 110: | 135                         | 138                        |
| 111: | 263                         | 266                        |





Note: There are cases where the HIGH period differs from tHIGH selected at SBIOCR1<SCK> when the rising edge of the SCL pin becomes blunt due to the load capacity of the bus.

In the master mode, the hold time when the start condition is generated is tHIGH [s] and the setup time when the stop condition is generated is  $t_{HIGH}$  [s]. When SBI0CR2<PIN> is set to "1" in the slave mode, the time that elapses before the release of the SCL pin is  $t_{LOW}$  [s]. In both the master and slave modes, the high level period must be 3/fcgck[s] or longer and the low level period must be 5/fcgck[s] or longer for the externally input clock, regardless of the SBI0CR1<SCK> setting.





#### 14.4.4.2 Clock synchronization

In the I2C bus, due to the structure of the pin, in order to drive a bus with a wired AND, a master device which pulls down a clock pulse to low will, in the first place, invalidate the clock pulse of another master device which generates a high-level clock pulse. Therefore, the master outputting the high level must detect this to correspond to it.

The serial bus interface circuit has a clock synchronization function. This function ensures normal transfer even if there are two or more masters on the same bus. The example explains clock synchronization procedures when two masters simultaneously exist on a bus.

# Page: 231/ 278





As Master 1 pulls down the SCL pin to the low level at point "a", the SCL line of the bus becomes the low level. After detecting this situation, Master 2 resets counting a clock pulse in the high level and sets the SCL pin to the low level.

Master 1 finishes counting a clock pulse in the low level at point "b" and sets the SCL pin to the high level. Since Master 2 holds the SCL line of the bus at the low level, Master 1 waits for counting a clock pulse in the high level. After Master 2 sets a clock pulse to the high level at point "c" and detects the SCL line of the bus at the high level, Master 1 starts counting a clock pulse in the high level. Then, the master, which has finished the counting a clock pulse in the high level, pulls down the SCL pin to the low level.

The clock pulse on the bus is determined by the master device with the shortest high-level period and the master device with the longest low-level period from among those master devices connected to the bus.

# 14.4.5 Master/slave selection

To set a master device, SBIOCR2<MST> should be set to "1".

To set a slave device, SBI0CR2<MST> should be cleared to "0". When a stop condition on the bus or an arbitration lost is detected, SBI0CR2<MST> is cleared to "0" by the hardware.

# 14.4.6 Transmitter/receiver selection

To set the device as a transmitter, SBIOCR2<TRX> should be set to "1". To set the device as a receiver, SBIOCR2<TRX> should be cleared to "0". For the I2C bus data transfer in the slave mode, SBIOCR2<TRX> is set to "1" by the hardware if the direction bit (R/W) sent from the master device is "1", and is cleared to "0" if the bit is "0".

In the master mode, after an acknowledge signal is returned from the slave device, SBIOCR2<TRX> is cleared to "0" by hardware if a transmitted direction bit is "1", and is set to "1" by hardware if it is "0".

# Page: 232 / 278

When an acknowledge signal is not returned, the current condition is maintained. When a stop condition on the bus or an arbitration lost is detected, SBI0CR2<TRX> is cleared to "0" by the hardware. Table 19-3 shows SBI0CR2<TRX> changing conditions in each mode and SBI0CR2<TRX> value after changing.

Note:: When SBI0CR1<NOACK> is "1", the slave address match detection and the GENERAL CALL detection are disabled, and thus SBI0CR2<TRX> remains unchanged.

| Mode           | Direction bit | Changing condition                           | TRX after changing |
|----------------|---------------|----------------------------------------------|--------------------|
| Slave mode     | "0"           | A received slave address is the              | "0"                |
|                | "1"           | same as the value set to<br>I2C0AR <sa></sa> | "1"                |
| Master<br>mode | "0"           | ACK signal is returned                       | "1"                |
|                | "1"           | ACK signal is returned                       | "0"                |

 Table 14.3
 SBIOCR1<TRX> Operation in Each Mode

When the serial bus interface circuit operates in the free data format, a slave address and a direction bit are not recognized. They are handled as data just after generating the start condition. SBI0CR2<TRX> is not changed by the hardware.

# 14.4.7 Start/stop condition generation

When SBIOSR2<BB> is "0", a slave address and a direction bit which are set to the SBIODBR are output on a bus after generating a start condition by writing "1" to SBIOCR2 <MST>, SBIOCR2<TRX>, SBIOCR2<BB> and SBIOCR2<PIN>. It is necessary to set SBIOCR1<ACK> to "1" before generating the start condition.



#### Figure 14.9 Generating the start condition and a slave address

When SBI0CR2<BB> is "1", the sequence of generating the stop condition on the bus is started by writing "1" to SBI0CR2<MST>, SBI0CR2<TRX> and SBI0CR2<PIN> and writing "0" to SBI0CR2<BB>.

When a stop condition is generated. The SCL line on a bus is pulled down to the low level by another device, a stop condition is generated after releasing the SCL line.

# Page: 233 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet



#### Figure 14.10 Stop condition generation

The bus condition can be indicated by reading the contents of SBIOSR2<BB>. SBIOSR2<BB> is set to "1" when the start condition on the bus is detected (Bus Busy State) and is cleared to "0" when the stop condition is detected (Bus Free State).

#### 14.4.8 Interrupt service request and release

When a serial bus interface circuit is in the master mode and transferring a number of clocks set by SBIOCR1<BC> and SBIOCR1<ACK> is complete, a serial bus interface interrupt request (INTSBIO) is generated.

In the slave mode, a serial bus interface interrupt request (INTSBIO) is generated when the above and following conditions are satisfied:

- At the end of the acknowledge signal when the received slave address matches to the value set by the I2COAR<SA> with SBI0CR1<NOACK> set at "0"

- At the end of the acknowledge signal when a "GENERAL CALL" is received with SBI0CR1<NOACK> set at "0"

- At the end of transferring or receiving after matching of the slave address or receiving of "GENERALCALL"

When a serial bus interface interrupt request occurs, SBI0CR2<PIN> is cleared to "0". During the time that SBI0CR2<PIN> is "0", the SCL0 pin is pulled down to the low level.

Writing data to SBI0DBR sets SBI0CR2<PIN> to "1". The time from SBI0CR2<PIN> being set to "1" until the SBI0 pin is released takes  $t_{LOW}$ .

Although SBIOCR2<PIN> can be set to "1" by the software, SBIOCR2<PIN> can not be cleared to "0" by the software.

# Page: 234 / 278

| MQ Technology Inc.    |                                                                                               |
|-----------------------|-----------------------------------------------------------------------------------------------|
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet Version : V1.1                                          |
| SCL0 pin1             | 2     3     7     8     9     SCL0 pin is pulled to low when sBIOCR2 <pin> is "0"     1</pin> |
| interrupt request     |                                                                                               |

Figure14.11 SBIOCR2<PIN> and SCL0 pin

# 14.4.9 Setting of serial bus interface mode

SBIOCR2<SBIM> is used to set serial bus interface mode. Setting SBIOCR2<SBIM> to "1" selects the serial bus interface mode. Setting it to "0" selects the port mode. Set SBIOCR2<SBIM> to "1" in order to set serial bus interface mode. Before setting of serial bus interface mode, confirm serial bus interface pins in a high level, and then, write "1" to SBIOCR2<SBIM>. And switch a port mode after confirming that a bus is free and set SBIOCR2<SBIM> to "0".

Note: When SBIOCR2<SBIM> is "0", no data can be written to SBIOCR2 except SBIOCR2<SBIM>. Before setting values to SBIOCR2, write "1" to SBIOCR2<SBIM> to activate the serial bus interface mode.

# 14.4.10 Software reset

The serial bus interface circuit has a software reset function that initializes the serial bus interface circuit. If the serial bus interface circuit locks up, for example, due to noise, it can be initialized by using this function. A software reset is generated by writing "10" and then "01" to SBIOCR2<SWRST>.

After a software reset is generated, the serial bus interface circuit is initialized and all the bits of SBIOCR2 register, except SBIOCR2<SBIM> and the SBIOCR1, I2COAR<SA> and SBIOSR2 registers, are initialized.

# 14.4.11 Arbitration lost detection monitor

Since more than one master device can exist simultaneously on a bus, a bus arbitration procedure is implemented in order to guarantee the contents of transferred data.

Data on the SDA line is used for bus arbitration of the I2C bus. The following shows an example of a bus arbitration procedure when two master devices exist simultaneously on a bus. Master 1 and Master 2 output the same data until point "a". After that, when Master 1 outputs "1" and Master 2 outputs "0", since the SDA line of a bus is wired AND, the SDA line is pulled down to the low level

# Page: 235/ 278

by Master 2. When the SCL line of a bus is pulled-up at point "b", the slave device reads data on the SDA line, that is data in Master 2. Data transmitted from Master 1 becomes invalid. The state in Master 1 is called "arbitration lost". A master device which loses arbitration releases the SDA pin and the SCL pin in order not to effect data transmitted from other masters with arbitration. When more than one master sends the same data at the first word, arbitration occurs continuously after the second word.





The serial bus interface circuit compares levels of a SDA line of a bus with its SDA pin at the rising edge of the SCL line. If the levels are unmatched, arbitration is lost and SBIOSR2<AL> is set to "1".

When SBIOSR2<AL> is set to "1", SBIOCR2<MST> and SBIOCR2<TRX> are cleared to "0" and the mode is switched to a slave receiver mode. Thus, the serial bus interface circuit stops output of clock pulses during data transfer after the SBIOSR2<AL> is set to "1". After the data transfer is completed, SBICR2<PIN> is cleared to "0" and the SCL pin is pulled down to the low level.

SBI0SR2<AL> is cleared to "0" by writing data to the SBI0DBR, reading data from the SBI0DBR or writing data to the SBI0CR2.

# Page: 236 / 278

# 汉芝电子股份有限公司

iMQ Technology Inc. No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1



Figure 14.13 Example when Master B is a serial bus interface circuit

#### 14.4.12 Slave address match detection monitor

In the slave mode, SBIOSR2<AAS> is set to "1" when the received data is "GENERAL CALL" or the received data matches the slave address setting by I2COAR<SA> with SBIOCR1<NOACK> set at "0" and the I2C bus mode is active (I2COAR<ALS>="0").

Setting SBIOCR1<NOACK> to "1" disables the subsequent slave address match and GENERAL CALL detections. SBIOSR2<AAS> remains at "0" even if a "GENERAL CALL" is received or the same slave address as the I2COAR<SA> set value is received.

When a serial bus interface circuit operates in the free data format (I2COAR<ALS>= "1"), SBI0SR2<AAS> is set to "1" after receiving the first 1-word of data. SBI0SR2<AAS> is cleared to "0" by writing data to the SBI0DBR or reading data from the SBI0DBR.

# Page: 237 / 278

| 汉芝电子股份有限公司            |                                                      |
|-----------------------|------------------------------------------------------|
| iMQ Technology Inc.   |                                                      |
| No. : TDDS01-M6812-EN | Name : MQ6812/MQ6821/MQ6822 Datasheet Version : V1.1 |
| SCL0 (Bus)            |                                                      |
| SDA0 (Bus)            | Start condition Slave address + Direction bit        |
| SDA0 pin              |                                                      |
| SBIOSR2 <aas></aas>   | Output of an acknowledge signal                      |
| -                     |                                                      |
| INTSBI0 Interrup<br>— | request                                              |

Figure 14.14 Change in the slave address match detection monitor

# 14.4.13 GENERAL CALL detection monitor

SBI0SR2<AD0> is set to "1" when SBI0CR1<NOACK> is "0" and GENERAL CALL (all 8-bit received data is "0" immediately after a start condition) in a slave mode.

Setting SBIOCR1<NOACK> to "1" disables the subsequent slave address match and GENERAL CALL detections. SBIOSR2<AD0> remains at "0" even if a "GENERAL CALL" is received.



Figure 14.15 Changes in the GENERAL CALL detection monitor

# 14.4.14 Last received bit monitor

The SDA line value stored at the rising edge of the SCL line is set to SBIOSR2<LRB>. In the acknowledge mode, immediately after an interrupt request is generated, an acknowledge signal is read by reading the contents of SBIOSR2<LRB>.

# Page: 238 / 278

| 汉芝电子股份有限公司<br>iMO Technology Inc. |                                                         |                |
|-----------------------------------|---------------------------------------------------------|----------------|
| No. : TDDS01-M6812-EN             | Name : MQ6812/MQ6821/MQ6822 Datasheet                   | Version : V1.1 |
| SCL 1                             | 2 3 4 5 6 7 8 9                                         |                |
| SDA                               | D6 V D5 V D4 V D3 V D2 V D1 V D0 V / / / Acknowledgment |                |
| SBI0SR2 <lrb>D7</lrb>             | D6 D5 D4 D3 D2 D1 D0 Acknowled                          | gment          |
| Figure                            | 14.16 Changes in the Last received bit monitor          |                |

#### 14.4.15 Slave address and address recognition mode specification

When the serial bus interface circuit is used in the I2C bus mode, clear I2C0AR<ALS> to "0", and set I2C0AR<SA> to the slave address.

When the serial bus interface circuit is used with a free data format not to recognize the slave address, set I2COAR<ALS> to "1". With a free data format, the slave address and the direction bit are not recognized, and they are processed as data from immediately after the start condition.

# 14.5 Data transfer of I2C Bus

# 14.5.1 Device initialization

Set POFFCR1<SBI0EN> to "1". After confirming that the serial bus interface pin is high level, set SBI0CR2<SBIM> to "1" to select the serial bus interface mode. Set SBI0CR1<ACK> to "1", SBI0CR1<NOACK> to "0" and SBI0CR1<BC> to "000" to count the number of clocks for an acknowledge signal, to enable the slave address match detection and the GENERAL CALL detection, and set the data length to 8 bits. Set  $t_{HIGH}$  and  $t_{LOW}$  at SBI0CR1<SCK>.

Set a slave address at I2COAR<SA> and set I2COAR<ALS> to "0" to select the I2C bus mode. Finally, set SBI0CR2<MST>, SBI0CR2<TRX> and SBI0CR2<BB> to "0", SBI0CR2<PIN> to "1" and SBI0CR2<SWRST> to "00" for specifying the default setting to a slave receiver mode.

Note1) : The initialization of a serial bus interface circuit must be complete within the time from all devices which are connected to a bus have initialized to and device does not generate a start condition. If not, the data cannot be received correctly because the other device starts transferring before an end of the initialization of a serial bus interface circuit.

Note2]: Set the related register before enable SBI/I2C function:

-Low power consumption register1 (POFFCR1)

Set POOFFCR1<SBI0EN> to"1", before enable SBI/I2C function, unless the SBI/I2C setting is invalid.

-Port P2 Output Control Registe (P2OUTCR)

Set P2OUTCR3 and P2OUTCR4 to"1", before enable SBI/I2C function

- Port P2 Output Latch Register (P2DR) Set P2DR to"0" before enable SBI/I2C function, unless the SBI/I2C function would operate unexpectedly.

# Page: 239/ 278

#### 14.5.2 Start condition and slave address generation

Confirm a bus free status (SBI0SR2<BB>="0"). Set SBI0CR1<ACK> to "1" and specify a slave address and a direction bit to be transmitted to the SBI0DBR. By writing "1" to SBI0CR2<MST>, SBI0CR2<TRX>, SBI0CR2<BB> and SBI0CR2<PIN>, the start condition is generated on a bus and then, the slave address and the direction bit which are set to the SBI0DBR are output. The time from generating the START condition until the falling SBI0 pin takes  $t_{HIGH}$ .

An interrupt request occurs at the 9th falling edge of a SCL clock cycle, and SBIOCR2<PIN> is cleared to "0". The SCL0 pin is pulled down to the low level while SBIOCR2<PIN> is "0". When an interrupt request occurs, SBIOCR2<TRX> changes by the hardware according to the direction bit only when an acknowledge signal is returned from the slave device.

Note 1: Do not write a slave address to the SBIODBR while data is transferred. If data is written to the SBIODBR, data to be output may be destroyed.

Note 2: The bus free state must be confirmed by software within 98.0 µs (the shortest transmitting time according to the standard mode I2C bus standard) or 23.7µs (the shortest transmitting time according to the fast mode I2C bus standard) after setting of the slave address to be output. Only when the bus free state is confirmed, set "1" to SBIOCR2<MST>, SBIOCR2<TRX>, SBIOCR2<BB> and SBIOCR2<PIN> to generate the start conditions. If the writing of slave address and setting of SBIOCR2<MST>, SBIOCR2<TRX>, SBIOCR2<TRX>, SBIOCR2<BB> and SBIOCR2<PIN> doesn't finish within 98.0µs or 23.7µs, the other masters may start the transferring and the slave address data written in SBIODBR may be broken.



Figure 14.17 Generating the start condition and the slave address

# Page: 240 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

#### 14.5.3 1-word data transfer

Check SBI0SR2<MST> by the interrupt process after a 1-word data transfer is completed, and determine whether the mode is a master or slave.

#### 14.5.3.1 When SBIOSR2<MST> is "1" (Master mode)

Check SBIOSR2<TRX> and determine whether the mode is a transmitter or receiver.

#### (a) When SBIOSR2<TRX> is "1" (Transmitter mode)

Check SBIOSR2<LRB>. When SBIOSR2<LRB> is "1", a receiver does not request data. Implement the process to generate a stop condition (described later) and terminate data transfer. When SBIOSR2<LRB> is "0", the receiver requests subsequent data. When the data to be transmitted subsequently is other than 8 bits, set SBIOCR1<BC> again, set SBIOCR1<ACK> to "1", and write the transmitted data to SBIODBR.

After writing the data, SBIOCR2<PIN> becomes "1", a serial clock pulse is generated for transferring the subsequent 1-word data from the SCL0 pin, and then the 1-word data is transmitted from the SDA0 pin.

After the data is transmitted, an interrupt request occurs. SBI0CR2<PIN> become "0" and the SCL0 pin is set to the low level. If the data to be transferred is more than one word in length, repeat the procedure from the SBI0SR2<LRB> checking above.





#### (b) When SBIOSR2<TRX> is "0" (Receiver mode)

When the data to be transmitted subsequently is other than 8 bits, set SBI0CR1<BC> again. Set

SBIOCR1< ACK> to "1" and read the received data from the SBIODBR (Reading data is undefined immediately after a slave address is sent).

After the data is read, SBI0CR2<PIN> becomes "1" by writing the dummy data (0x00) to the

#### Page: 241 / 278



#### Figure 14.19 Example when SBIOCR1<BC>="000" and SBIOCR1<ACK>="1

To make the transmitter terminate transmission, execute following procedure before receiving a last data.

- 1. Read the received data.
- 2. Clear SBIOCR1<ACK> to "0" and set SBIOCR1<BC> to "000".
- 3. To set SBIOCR2<PIN> to "1", write a dummy data (0x00) to SBIODBR.

Transfer 1-word data in which no clock is generated for an acknowledge signal by setting SBI0CR2<PIN> to "1". Next, execute following procedure.

- 1. Read the received data.
- 2. Clear SBIOCR1<ACK> to "0" and set SBIOCR1<BC> to "001".
- 3. To set SBIOCR2<PIN> to "1", write a dummy data (0x00) to SBIODBR.

Transfer 1-bit data by setting SBIOCR1<PIN> to "1".

In this case, since the master device is a receiver, the SDA line on a bus keeps the high level. The transmitter receives the high-level signal as a negative acknowledge signal. The receiver indicates to the transmitter that data transfer is complete.

After 1-bit data is received and an interrupt request has occurred, generate the stop condition to terminate data transfer.

#### Page: 242 / 278

# 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet



Figure 14.20 Termination of Data Transfer in the Master Receiver Mode

#### 14.5.3.2 When SBIOSR2<MST> is "0" (slave mode)

In the slave mode, a serial bus interface circuit operates either in the normal slave mode or in the slave mode after losing arbitration.

In the slave mode, the conditions of generating the serial bus interface interrupt request (INTSBIO) are follows:

- At the end of the acknowledge signal when the received slave address matches the value set by the I2C0AR<SA> with SBI0CR1<NOACK> set at "0"

- At the end of the acknowledge signal when a "GENERAL CALL" is received with SBI0CR1<NOACK> set at "0"

- At the end of transferring or receiving after matching of slave address or receiving of "GENERAL CALL"

The serial bus interface circuit changes to the slave mode if arbitration is lost in the master mode. And an interrupt request occurs when the word data transfer terminates after losing arbitration.

The generation of the interrupt request and the behavior of SBI0CR2<PIN> after losing arbitration are shown in Table14-4 °

|                     | When the Arbitration Lost Occurs during Transmission of Slave Address as a Master | When the Arbitration Lost Occurs during Transmission<br>of Data as Master Transmitter |  |  |  |
|---------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|
| interrupt request   | An interrupt request is generated at the termination of word-data transfer.       |                                                                                       |  |  |  |
| SBI0CR2 <pin></pin> | SBI0CR2 <pin> is cleared to "0".</pin>                                            |                                                                                       |  |  |  |

#### Table 14.4 The behavior of an interrupt request and SBI0CR2<PIN> after losing arbitration

When an interrupt request occurs, SBI0CR2<PIN> is reset to "0", and the SCL0 pin is set to the low level. Either writing data to the SBI0DBR or setting SBI0CR2<PIN> to "1" releases the SCL0 pin after taking  $t_{LOW}$ . Check SBI0SR2<AL>, SBI0SR2<TRX>, SBI0SR2<AAS> and SBI0SR2<ADO> and implement processes according to conditions listed in table 14.5.

# Page: 243 / 278

# 汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| SBI0SR2<<br>TRX> | SBI0SR2<<br>AL> | SBI0SR2<<br>AAS>      | SBI0SR2<<br>AD0>                                                                                                 | Conditions                                                                                                                                                                                                                                                                                                                                                                                                      | Process                                                                                                                                                                                     |
|------------------|-----------------|-----------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 1               | 1 1 0 and re<br>value |                                                                                                                  | The serial bus interface circuit loses arbi-<br>tration when transmitting a slave address,<br>and receives a slave address of which the<br>value of the direction bit sent from another<br>master is "1".                                                                                                                                                                                                       | Set the number of bits in 1 word to<br>SBI0CR1 <bc> and write the transmitted</bc>                                                                                                          |
| 1                |                 | 1                     | 0                                                                                                                | In the slave receiver mode, the serial bus<br>interface circuit receives a slave address<br>of which the value of the direction bit sent<br>from the master is "1".                                                                                                                                                                                                                                             | data to the SBI0DBR.                                                                                                                                                                        |
| 0                | 0 0             |                       | In the slave transmitter mode, the serial<br>bus interface circuit finishes the transmis-<br>sion of 1-word data | Check SBI0SR2 <lrb>. If it is set to "1", set<br/>SBI0CR2<pin> to "1" since the receiver<br/>does not request subsequent data. Then,<br/>clear SBI0CR2<trx> to "0" to release the<br/>bus. If SBI0SR2<lrb> is set to "0", set the<br/>number of bits in 1 word to SBI0CR1<bc><br/>and write the transmitted data to SBI0DBR<br/>since the receiver requests subsequent da-<br/>ta.</bc></lrb></trx></pin></lrb> |                                                                                                                                                                                             |
|                  | 1               | 1                     | 1/0                                                                                                              | The serial bus interface circuit loses arbi-<br>tration when transmitting a slave address,<br>and receives a slave address of which the<br>value of the direction bit sent from another<br>master is "0" or receives a "GENERAL<br>CALL".                                                                                                                                                                       | Write the dummy data (0x00) to the<br>SBI0DBR to set SBI0CR2 <pin> to "1", or<br/>write "1" to SBI0CR2<pin>.</pin></pin>                                                                    |
| 0                |                 | 0                     | 0                                                                                                                | The serial bus interface circuit loses arbi-<br>tration when transmitting a slave address<br>or data, and terminates transferring the<br>word data.                                                                                                                                                                                                                                                             | The serial bus interface circuit is changed<br>to the slave mode. Write the dummy data<br>(0x00) to the SBI0DBR to clear<br>SBI0SR2 <al> to "0" and set<br/>SBI0CR2<pin> to "1".</pin></al> |
|                  |                 | 1                     | 1/0                                                                                                              | In the slave receiver mode, the serial bus<br>interface circuit receives a slave address<br>of which the value of the direction bit sent<br>from the master is "0" or receives "GEN-<br>ERAL CALL".                                                                                                                                                                                                             | Write the dummy data (0x00) to the SBI0DBR to set SBI0CR2 <pin> to "1", or write "1" to SBI0CR2<pin>.</pin></pin>                                                                           |
|                  |                 | 0                     | 1/0                                                                                                              | In the slave receiver mode, the serial bus interface circuit terminates the receipt of 1-word data.                                                                                                                                                                                                                                                                                                             | Set the number of bits in 1-word to SBI0CR1 <bc>, read the received data from the SBI0DBR and write the dummy data (0x00).</bc>                                                             |

#### Table 14.5 Operation in the slave mode

Note: In the slave mode, if the slave address set in I2COAR<SA> is "0x00", a START Byte "0x01" in I2C bus standard is received, the device detects slave address match and SBI0CR2<TRX> is set to "1". Do not set I2COAR<SA> to "0x00".

# 14.5.4 Stop condition generation

When SBI0CR2<BB> is "1", a sequence of generating a stop condition is started by setting "1" to SBI0CR2<MST>, SBI0CR2<TRX> and SBI0CR2<PIN> and clearing SBI0CR2<BB> to "0". Do not modify the contents of SBI0CR2<MST>, SBI0CR2<TRX>, SBI0CR2<BB> and SBI0CR2<PIN> until a stop condition is generated on a bus.

When a SCL line on a bus is pulled down by other devices, a serial bus interface circuit generates a stop condition after a SCL line is released. The time from the releasing SCL line until the generating the STOP condition takes t<sub>HIGH</sub>.

# Page: 244 / 278



Figure 14.21 Stop Condition Generation

### 14.5.5 Restart

Restart is used to change the direction of data transfer between a master device and a slave device during transferring data. The following explains how to restart the serial bus interface circuit.

Clear SBIOCR2<MST>, SBIOCR2<TRX> and SBIOCR2<BB> to "0" and set SBIOCR2 <PIN> to "1". The SDA0 pin retains the high level and the SCL0 pin is released.

Since this is not a stop condition, the bus is assumed to be in a busy state from other devices. Check SBIOSR2<BB> until it becomes "0" to check that the SCL0 pin of the serial bus interface circuit is released.

Check SBIOSR2<LRB> until it becomes "1" to check that the SCL line on the bus is not pulled down to the low level by other devices.

After confirming that the bus stays in a free state, generate a start condition in the procedure "Start condition and slave address generation".

In order to meet the setup time at a restart, take at least 4.7µs of waiting time by the software in the standard mode I2C bus standard or at least 0.6µs of waiting time in the fast mode I2C bus standard from the time of restarting to confirm that a bus is free until the time to generate a start condition.

Note: When the master is in the receiver mode, it is necessary to stop the data transmission from the slave device before the STOP condition is generated. To stop the transmission, the master device make the slave device receiving a negative acknowledge. Therefore, SBIOSR2<LRB> is "1" before generating the Restart and it can not be confirmed that SCL line is not

# Page: 245 / 278

iMQ Technology Inc.

No. : TDDS01-M6812-EN

#### Name : MQ6812/MQ6821/MQ6822 Datasheet



Figure 14.22 Timing diagram when restarting

# 14.6 AC Specifications

The operating mode (fast or standard) mode should be selected suitable for frequency of fcgck. For these operating mode, refer to the following table.

|                                                                                                        |                     | Standar                 | d mode        | Fast                    | mode          |      |
|--------------------------------------------------------------------------------------------------------|---------------------|-------------------------|---------------|-------------------------|---------------|------|
| Parameter                                                                                              | Symbol              | MIN.                    | MAX.          | MIN.                    | MAX.          | Unit |
| SCL clock frequency                                                                                    | f <sub>SCL</sub>    | 0                       | fcgck / (m+n) | 0                       | fcgck / (m+n) | kHz  |
| Hold time (re)start condition. This peri-<br>od is followed by generation of the first<br>clock pulse. | thd;sta             | m / fcgck               | -             | m / fcgck               | -             | μs   |
| Low-level period of SCL clock (output)                                                                 | t <sub>LOW</sub>    | n / fcgck               | -             | n / fcgck               | -             | μs   |
| High-level period of SCL clock (output)                                                                | t <sub>HIGH</sub>   | m / fcgck               | -             | m / fcgck               | -             | μs   |
| Low-level period of SCL clock (input)                                                                  | t <sub>LOW</sub>    | 5 / fcgck               | -             | 5 / fcgck               | -             | μs   |
| High-level period of SCL clock (input)                                                                 | t <sub>HIGH</sub>   | 3 / fcgck               | -             | 3 / fcgck               | -             | μs   |
| Restart condition setup time                                                                           | t <sub>SU;STA</sub> | Depends on the software | -             | Depends on the software | -             | μs   |
| Data hold time                                                                                         | t <sub>HD;DAT</sub> | 0                       | 5 / fcgck     | 0                       | 5 / fcgck     | μs   |
| Data setup time                                                                                        | t <sub>SU;DAT</sub> | 250                     | -             | 100                     | -             | ns   |
| Rising time of SDA and SCL signals                                                                     | tr                  | -                       | 1000          | -                       | 300           | ns   |
| Falling time of SDA and SCL signals                                                                    | t <sub>f</sub>      | -                       | 300           | -                       | 300           | ns   |
| Stop condition setup time                                                                              | t <sub>su;sто</sub> | m / fcgck               | -             | m / fcgck               | -             | μs   |
| Bus free time between the stop condi-<br>tion and the start condition                                  | t <sub>BUF</sub>    | Depends on the software | -             | Depends on the software | -             | μs   |
| Time before rising of SCL after<br>SBICR2 <pin> is changed from "0" to<br/>"1"</pin>                   | t <sub>SU;SCL</sub> | n / fcgck               | _             | n / fcgck               | _             | μs   |

Table 14.6 AC Specifications (Circuit Output Timing)

Page: 246 / 278

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Note: For m and n, refer to "14.4.4.1 clock source"



Figure 14.23 Definition of Timing (No.1)



Figure 14.24 Definition of Timing (No.2)

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 15 Synchronous Serial Interface (SIO)

MQ6812/MQ66821 contains 1 channel of 8-bit serial interface of the clock synchronization type.

|      | SIOxCR<br>(Address) | SIOxSR<br>(Address) | SIOxBUF<br>(Address) |
|------|---------------------|---------------------|----------------------|
| 5100 | SIOOCR              | SIOOSR              | SIOOBUF              |
| SIOO | (0x001F)            | (0x0020)            | (0x0021)             |

#### Table 15.1 SFR Address Assignment

|      | Serial clock     | Serial data | Serial data |
|------|------------------|-------------|-------------|
|      | Input/output pin | Input pin   | output pin  |
| SIOO | SCLK0 pin        | SIO pin     | SO0 pin     |

#### Table 15.2 Pin Names

#### Configuration 15.1



#### Figure 15.1 Serial Interface

Note: The serial interface input/output pins are also used as the I/O ports. The I/O port register settings are required to use these pins for a serial interface.

# 15.2 Control

The synchronous serial interface SIO0 is controlled by the low power consumption registers (POFFCR2) the serial interface data buffer register (SIO0BUF), the serial interface control register (SIO0CR) and the serial interface status register(SIO0SR).

#### Low power consumption register 2

| POFFCR2<br>(0x0F76) | 7     | 6 | 5     | 4 | 3 | 2 | 1 | 0             |
|---------------------|-------|---|-------|---|---|---|---|---------------|
| Bit Symbol          | LCDEN | - | RTCEN | - | - | - | - | <b>SIO0EN</b> |
| Read/Write          | R/W   | R | R/W   | R | R | R | R | R/W           |
| After reset         | 0     | 0 | 0     | 0 | 0 | 0 | 0 | 0             |

| LCDEN  | LCD control  | 0: Disable<br>1: Enable |
|--------|--------------|-------------------------|
| RTCEN  | RTC control  | 0: Disable<br>1: Enable |
| sio0en | SIO0 control | 0: Disable<br>1: Enable |

#### Serial interface buffer register

| SIO0BUF<br>(0x0021) | 7 | 6             | 5 | 2 | 1 | 0 |   |   |  |  |
|---------------------|---|---------------|---|---|---|---|---|---|--|--|
| Bit Symbol          |   | SIOOBUF       |   |   |   |   |   |   |  |  |
| Read/Write          | R | R R R R R R R |   |   |   |   |   |   |  |  |
| After reset         | 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

#### Serial interface buffer register

| SIO0BUF<br>(0x0021) | 7 | 6       | 5  | 4 | 3 | 2 | 1  | 0 |  |  |
|---------------------|---|---------|----|---|---|---|----|---|--|--|
| Bit Symbol          |   | SIOOBUF |    |   |   |   |    |   |  |  |
| Read/Write          | W | W       | W/ | W | W | W | W/ | W |  |  |
| After reset         | 1 | 1       | 1  | 1 | 1 | 1 | 1  | 1 |  |  |

Note: SIO0BUF is the data buffer for both transmission and reception. The last received data is read each time SIO0BUF us read. If SIO0BUF has never received data, it is read as "0". When data is written into it, the data is treated as the transmit data.

#### Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| S | erial interface | e control re | egister |  |
|---|-----------------|--------------|---------|--|
|   | SIOOCR          |              |         |  |

| SIOOCR<br>(0x001F) | 7      | 6      | 5   | 4   | 3      | 2    | 1   | 0   |
|--------------------|--------|--------|-----|-----|--------|------|-----|-----|
| Bit Symbol         | SIOEDG | SIOCKS |     |     | SIODIR | SIOS | SIC | M   |
| Read/Write         | R/W    | R/W    | R/W | R/W | R/W    | R/W  | R/W | R/W |
| After reset        | 0      | 0      | 0   | 0   | 0      | 0    | 0   | 0   |

| CIOEDE                            |                               | 0:Rece                             | eive data at a rising edge and tr | ansmit data at a falling edge  |  |  |  |
|-----------------------------------|-------------------------------|------------------------------------|-----------------------------------|--------------------------------|--|--|--|
| SIOEDG                            | Transfer edge selection       | 1:Tran                             | smit data at a rising edge and r  | eceive data at a falling edge. |  |  |  |
|                                   |                               |                                    | NORMAL1/2 or IDLE 1/2             | SLOW 1/2 or SLEEP 1            |  |  |  |
|                                   |                               |                                    | mode                              | mode                           |  |  |  |
|                                   |                               | 000                                | fcgck/2 <sup>9</sup>              | -                              |  |  |  |
|                                   |                               | 001                                | fcgck/2 <sup>6</sup>              | -                              |  |  |  |
| SIOCKS Serial clock selection[Hz] | 010                           | fcgck/2 <sup>5</sup>               | -                                 |                                |  |  |  |
|                                   | Serial clock selection[Hz]    | 011                                | fcgck/2 <sup>4</sup>              | -                              |  |  |  |
|                                   |                               | 100                                | fcgck/2 <sup>3</sup>              | -                              |  |  |  |
|                                   |                               | 101                                | fcgck/2 <sup>2</sup>              | -                              |  |  |  |
|                                   |                               | 110                                | fcgck/2                           | fs/2 <sup>3</sup>              |  |  |  |
|                                   |                               | 111                                | Ext. clock input                  |                                |  |  |  |
| SIODIR                            | Transfor format (MSD/LSD)     |                                    | first (transfer from bit 0)       |                                |  |  |  |
| SIODIK                            | Transfer format (MSB/LSB)     | 1: MSB first (transfer from bit 7) |                                   |                                |  |  |  |
| SIOS                              | Transfer operation start/stop | 0:Operation stop (reserved stop)   |                                   |                                |  |  |  |
| SIOS                              | instruction                   | 1:Ope                              | ration start                      |                                |  |  |  |
|                                   |                               | 00:Operation stop (forced stop)    |                                   |                                |  |  |  |
| SIOM                              | Transfer mode selection and   | 01: 8-bit transmit mode            |                                   |                                |  |  |  |
| 510101                            | operation                     | 10:8-bit receive mode              |                                   |                                |  |  |  |
|                                   |                               | 11:8-b                             | it transmit and receive mode      |                                |  |  |  |

Note 1: fcgck is Gear clock (Hz) · fs is low-frequency clock (Hz) ·

Note2: After the operation is started (writing "1" to SIOS), writing to SIOEDG, SIOCKS and SUIDUR is invalid until SIOOSR<SIOF> becomes"0". (SIOEDGE, SIOCKS and SIODIR can be changed at the same time as changing SIOS from "0" to"1")

Note3: After the operation is started (writing "1" to SIOS), no values other than "00" can be written to SIOM until SIOF becomes "0" (if a value from "01" to "11" is written to SIOM, it is ignored). The transfer mode cannot be changed during the operation. Note4: SIOS remains at "0", if "1" is written to SIOS when SIOM is "00" (operation stop).

Note5: When SIO is used in SLOW1/2 or SLEEP1 mode, be sure to set SIOCKS to "110". If SIOCKs is set to any other value SIO will not operate. When SIO is used in SLOW1/2 or SLEEP1 mode, execute communications with SIOCKS="110" in advance or change SIOCKs after SIO is stopped.

Note6: When STOP, IDLE0 or SLEEP0 mode is activated, SIOM is automatically cleared to "00" and SIO stops the operation. Meanwhile, SIOS is cleared to "0". However, the values set for SIOEDG, SIOCKS and SIODIR are maintained.

Serial interface status register

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| SIO0SR<br>(0x0020) | 7    | 6   | 5    | 4     | 3    | 2    | 1 | 0 |
|--------------------|------|-----|------|-------|------|------|---|---|
| Bit Symbol         | SIOF | SEF | OERR | RENDB | UERR | TBFL | - | - |
| Read/Write         | R    | R   | R    | R     | R    | R    | R | R |
| After reset        | 0    | 0   | 0    | 0     | 0    | 0    | 0 | 0 |

| SIOF  | Serial transfer operation status monitor | 0:Transfer not in progress<br>1:Transfer in progress                                                                                  |
|-------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| SEF   | Shift operation status monitor           | 0:Shift operation not in progress<br>1:Shift operation in progress                                                                    |
| OERR  | Receive overrun error flag               | 0:No overrun error has occurred<br>1:At least one overrun error has occurred                                                          |
| RENDB | Receive completion flag                  | 0: At least one data receive operation has been executed<br>1: No data has been received since the last received data<br>was read out |
| UERR  | Transmit underrun error flag             | 0: No transmit underrun error has occurred<br>1:At least one transmit underrun error has occurred                                     |
| TBFL  | Transmit buffer full flag                | 0:The transmit buffer is empty<br>1:The transmit buffer has the data that has not yet been<br>transmitted                             |

Note 1: The OERR and UERR flags are cleared by reading SIOOSR.

Note2: The REND flag is cleared by reading SIO0BUF.

Note3: Writing "00" to SIO0CR<SIOM> clears all the bits of SIO0SR to "0", whether the serial interface is operating or not. When STOP, IDLEO or SLEEPO mode is activated, SIOM is automatically cleared ti "00" and all the bits of SIOOSR are cleared to "0" Note 4: Bit 1 to 0 of SIOOSR are read"0".

# 15.3 Low power consumption function

Serial interface 0 has the low power consumption registers (POFFCR2) that save power when the serial interface is not being used.

Setting POFFCR2<SIO0EN> to "0" disables the basic clock supply to serial interface 0 to save power. Note that this renders the serial interface unusable. Setting POFFCR2<SIO0EN> to "1" enables the basic clock supply to serial interface 0 and allows the serial interface to operate.

After reset, POFFCR2<SIO0EN> are initialized to "0", and this renders the serial interface unusable. When using the serial interface for the first time, be sure to set POFFCR2<<SIO0EN> to "1" in the initial setting of the program (before the serial interface control registers are operated).

During the serial interface operation, do not change POFFCR2<SIO0EN> to "0". Otherwise serial interface 0 may operate unexpectedly.

No. : TDDS01-M6812-EN Name :

Name : MQ6812/MQ6821/MQ6822 Datasheet

# 15.4 Functions

### 15.4.1 Transfer format

The transfer format can be set to either MSB or LSB first by SIOOCR<SIODIR>. Setting SIOCR<SIODIR> to "0" selects LSB first as the transfer format. In this case the serial data is transferred in sequence from the least significant bit.

Setting SIO0CR<SIODIR> to "1" selects MSB first as the transfer format. In this case, the serial data is transferred in sequence from the most significant bit.

#### 15.4.2 Serial clock

The serial clock can be selected by using SIOOCR <SIOCK>. Setting SIOOCR <SIOCKS> to "000" to 1 10" selects the internal clock as the serial clock. In this case, the serial clock is output from the SCLK0 pin. The serial data is transferred in synchronization with the edge of the SCLK0 pin output.

Setting SIOOCR<SIOCKS> to "111" selects an external clock as the serial clock. In this case, an external serial clock must be input to the SCLK0 pin. The serial data is transferred in synchronization with the edge of the external clock.

The serial data transfer edge can be selected for both the external and internal clocks. For details, refer to "15.4.3 Transfer edge selection".

|                             | Serial clock [Hz]                 |                           | fcgck=            | ⁼4MHz                 | fcgck=8MHz        |                       | fcgck=10MHz       |                       | fs=32.768kHz      |                       |
|-----------------------------|-----------------------------------|---------------------------|-------------------|-----------------------|-------------------|-----------------------|-------------------|-----------------------|-------------------|-----------------------|
| SIOOCR<br><siocks></siocks> | NORMAL 1/2<br>or IDLE 1/2<br>mode | SLOW1/2 or<br>SLEEP1 mode | 1-bit<br>time(us) | Baud<br>rate<br>(bps) | 1-bit<br>time(us) | Baud<br>rate<br>(bps) | 1-bit<br>time(us) | Baud<br>rate<br>(bps) | 1-bit<br>time(us) | Baud<br>rate<br>(bps) |
| 000                         | fcgck/2 <sup>9</sup>              | -                         | 128               | 7.813k                | 64                | 15.625k               | 51.2              | 19.531k               | -                 | -                     |
| 001                         | fcgck/2 <sup>6</sup>              | -                         | 16                | 62.5k                 | 8                 | 125k                  | 6.4               | 156.25k               | -                 | -                     |
| 010                         | fcgck/2 <sup>5</sup>              | -                         | 8                 | 125k                  | 4                 | 250k                  | 3.2               | 312.5k                | -                 | -                     |
| 011                         | fcgck/2 <sup>4</sup>              | -                         | 4                 | 250k                  | 2                 | 500k                  | 1.6               | 625k                  | -                 | -                     |
| 100                         | fcgck/2 <sup>3</sup>              | -                         | 2                 | 500k                  | 1                 | 1M                    | 0.8               | 1.25M                 | -                 | -                     |
| 101                         | fcgck/2 <sup>2</sup>              | -                         | 1                 | 1M                    | 0.5               | 2M                    | 0.4               | 2.5M                  | -                 | -                     |
| 110                         | fcgck/2                           | fs/2 <sup>3</sup>         | 0.5               | 2M                    | 0.25              | 4M                    | 0.2               | 5M                    | 244               | 4k                    |

Table 15.3 Transfer Baud Rate

#### Page: 252 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 15.4.3 Transfer edge selection

The serial data transfer edge can be selected by using SIOCR<SIOEDG>.

| SIOOCR <sioedg></sioedg> | Data transmission | Data reception |  |
|--------------------------|-------------------|----------------|--|
| 0                        | Falling edge      | Rising edge    |  |
| 1                        | Rising edge       | Falling edge   |  |

## Table 15.4 Transfer Edge Selection

When SIOCR<SIOEDG> is  $0 \cdot$  the data is transmitted in synchronization with the falling edge of the clock and the data is received in synchronization with the rising edge of the clock.

When SIOCR<SIOEDG> is "1"  $\cdot$  the data is transmitted in synchronization with the rising edge of the clock and the data is received in synchronization with the falling edge of the clock.



SIOCR<SIOEDG> = "1"

Figure 15.2 Transfer Edge

Note: When an external clock input is used, 4/fcgck or longer is needed between the receive edge at the 8th bit and the transfer edge at the first bit of the next transfer.

## Page: 253 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

## 15.5 Transfer Modes

## 15.5.1 8-bit transmit mode

Setting SIO0CR<SIOM> to "01", to select 8-bit transmit mode.

## 15.5.1.1 Setting

Before starting the transmit operation, select the transfer edges at SIO0CR<SIOEDG>, a transfer format at SIO0CR <SIODIR> and a serial clock at SIO0CR<SIOCKS>. To use the internal clock as the serial clock, select an appropriate serial clock at SIO CR<SIOCKS>. To use an external clock as the serial clock, set SIO0CR<SIOCKS> to "111".

Setting SIO0CR<SIOM>to" 01", to select the 8-bit transmit mode.

The transmit operation is started by writing the first byte of transmit data to SIO0BUF and then setting SIO0CR<SIOS> to "1".

Writing data to SIOOCR<SIOEDG, SIOCKS and SIODIR> is invalid when the serial communication is in progress, or when SIOOSR <SIOF> is 1. Make these setting while the serial communication is stopped. While the serial communication is in progress (SIOOSR<SIOF>="1"), only writing "00" to SIOOCR<SIOM> or writing "0" to SIOOCR<SIOS> is valid.

## 15.5.1.2 Starting the transmit operation

The transmit operation is started by writing data to SIOBUF and then setting SIOOCR<SIOS> to "1". The transmit data is transferred from SIO0BUF to the shift register, and then transmitted as the serial data from the SO0 pin according to the settings of SIO0CR<SIOEDG, SIOCKs an SIODIR>. The serial data becomes undefined if the transmit operation is started without writing any transmit data to SIO0BUF.

In the internal clock operation, the serial clock of the selected baud rate is output from the SCLK0 pin. In the external clock operation, an external clock must be supplied to the SCLK0 pin. By setting SIO0CR<SIOS> to "1", SIO0SR<SIOF and SEF> are automatically set to "1" and an INTSIO0interrupt request is generated. SIO0SR <SEF> is cleared to "0" when the 8<sup>th</sup> bit of the serial data is output.

### 15.5.1.3 Transmit buffer and shift operation

If data is written to SIO0BUF when the serial communication is in progress and the shift register is empty, the written data is transferred to the shift register immediately. At this time, SIO0SR<TBFL> remains at "0". If data is written to SIO0BUF when some data remains in the shift register, SIO0SR<TBFL> is set to "1". If new data is written to SIO0BUF in this state, the contents of SIO0BUF are overwritten by the new value. Make sure that SIO0SR<TBFL> is "0" before writing data to SIO0BUF.

## Page: 254 / 278

## 15.5.1.4 Operation on completion of transmission

The operation on completion of the data transmission varies depending on the operating clock and the state of SIO0SR<TBFL>.

### (a) When the internal clock is used and SIO0SR<TBFL> is "0"

When the data transmission is completed, the SCLKO pin becomes the initial state and the SOO pin becomes the "H" level. SIOOSR<SEF> remains at "0". When the internal clock is used, the serial clock and data output is stopped until the next transmit data is written into SIOOBUF (automatic wait).

When the subsequent data is written into SIO0BUF, SIO0SR<SEF> is set to "1", the SCLK0 pin outputs the serial clock, and the transmit operation is restarted. An INTSIO0 interrupt request is generated at the restart of the transmit operation.

## (b)When an external clock is used and SIO0SR<TBFL> is "0"

When the data transmission is completed, the SO pin keeps last output value. When an external serial clock is input to the SCLK0 pin after completion of the data transmission, an undefined value is transmitted and the transmit underrun error flag SIO0SR<UERR> is set to "1".

If a transmit underrun error occurs, data must not be written to SIO0BUF during the transmission of an undefined value. It is recommended to finish the transmit operation by setting SIO0CR<SIOS> to "0" or force the transmit operation to stop by setting SIO0CR<SIOM> to "00".

The transmit underrun error flag SIO0SR<UERR> is cleared by reading SIO0SR.

#### (c) When an internal or external clock is used an SIO0SR<TBFL> is "1"

When the data transmission is completed, SIOOSR<TBFL> is cleared to "0". The data in SIOOBUF

Is transferred to the shift register and the transmission of subsequent data is started. At this time, SIO0SR<SEF> is set to "1" and an INTSIO0 interrupt request is generated.

## 15.5.1.5 Stopping the transmit operation

Set SIO0CR<SIOS> to "0" to stop the transmit operation. When SIO0SR<SEF> is "0", or when the shift operation is not in progress, the transmit operation is stopped immediately and an INTSIO0 interrupt request is generated. When SIO0SR<SEF> is "1", the transmit operation is stopped after all the data in the shift register is transmitted (reserved stop). At this time, an INTSIO0 interrupt request is generated again.

## Page: 255 / 278

When the transmit operation is completed, SIOOSR<SIOF, SEF and TBFL> are cleared to "0". Other SIOOSR registers keep their values.

If the internal clock has been used, the SOO pin automatically returns to the "H" level. If an external clock has been used, the SOO pin keeps the last output value. To return the SOO pin to the "J" level, write "00" to SIOOCR<SIOM> when the operation is stopped.

The transmit operation can be forced to stop by setting SIOOCR<SIOM> to "00" during the operation. By setting SIOOCR<SIOM> to "00", SIOOCR<SIOS> and SIOOSR are cleared to "0" and the SIO stops the operation, regardless of the SIOOSR <SEF> value. The SOOpin becomes the "H" level. If the internal clock is selected, the SCLK0 pin returns to the initial level.



Figure 15.4 8-bit Transmit Mode (Internal Clock and Reserved Stop)

## Page: 256 / 278

## 汉芝电子股份有限公司

iMQ

No.

| chnology Inc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                               |                   |                                      |                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-------------------|--------------------------------------|------------------|
| DDS01-M6812-EN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Name : MQ6812                                 | 2/MQ6821/MQ6      | 5822 Datasheet                       | Version : V      |
| Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | operation<br>I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                             | Froced stop       | Start operation                      |                  |
| SIOCR <sios></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                               |                   |                                      |                  |
| siosr <siom></siom>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <u> </u><br> <br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                             | 1 00              | 01                                   |                  |
| siosr <siof></siof>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1-4- 0                                        |                   |                                      |                  |
| SIOSR <sef></sef>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | data A                                        |                   |                                      |                  |
| SIOSR <tbfl></tbfl>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                               |                   |                                      |                  |
| Internal clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | uninn                                         | ninnr             | uujuuu                               |                  |
| SCLK pin ———<br>(output)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | mhm                                           | лţ                |                                      |                  |
| SO pin<br>(output)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | data /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | A I data E<br>Bit4/Bit5/Bit6/Bit7/Bit0/Bit1/E | $\neg$            | Bit0/Bit1/Bit2/Bit3/Bit4             | 4/Bit5/Bit6/Bit7 |
| SS pin<br>(output)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <br> <br> <br>                                |                   |                                      |                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <u>h</u>                                      |                   | 'n                                   |                  |
| SIOBUF (write buffer)<br>Write to SIOBUF Writing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | data A Writing data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | В                                             |                   | Writing data C                       |                  |
| (write buffer)<br>Write to<br>SIOBUF Writing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | data A Writing data l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <sup>B</sup><br>B-bit Transmit mod            | de(Internal clock | -                                    |                  |
| (write buffer)<br>Write to<br>SIOBUF Writing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | data A Writing data l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                               | de(Internal clock | and forced stop                      |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | data A Writing data l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 8-bit Transmit moo                            | -                 | and forced stop                      |                  |
| (write buffer)<br>Write to<br>SIOBUF Writing<br>StocR <sios><br/>SIOSR<siom></siom></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | data A Writing data l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                               | -                 | and forced stop                      | <br>             |
| (write buffer)<br>Write to<br>SIOBUF<br>Vriting<br>Start<br>SIOCR <sios><br/>SIOSR<siom><br/>SIOSR<siof></siof></siom></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | data A Writing data l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 8-bit Transmit moo                            | -                 | and forced stop                      |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Vriting<br>Store<br>SIOCR <sios><br/>SIOSR<siof><br/>SIOSR<sef></sef></siof></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | data A Writing data l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 8-bit Transmit moo                            | -                 | and forced stop                      | <br>             |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>Start<br>SIOCR <sios><br/>SIOSR<siof><br/>SIOSR<siof><br/>SIOSR<sef><br/>SIOSR<tbfl></tbfl></sef></siof></siof></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | data A Writing data l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 8-bit Transmit moo                            | -                 | and forced stop                      |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>SIOCR <sios><br/>SIOCR<sios><br/>SIOSR<siof><br/>SIOSR<siof><br/>SIOSR<sef><br/>SIOSR<uerr><br/>SIOSR<uerr><br/>SCLK pin<br/>(output)<br/>SO pin</uerr></uerr></sef></siof></siof></sios></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | data A Writing data A Grant data A Writing data A Grant d |                                               |                   | and forced stop                      |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>Start<br>SIOCR <sios><br/>SIOSR<siof><br/>SIOSR<sif><br/>SIOSR<tbfl><br/>SIOSR<uerr><br/>SCLK pin<br/>(output)</uerr></tbfl></sif></siof></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | data A Writing data A Grant data A Writing data A Grant d |                                               |                   | <b>and forced stop</b> Reserved stop |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>SIOCR <sios><br/>SIOSR<siom><br/>SIOSR<siof><br/>SIOSR<siof><br/>SIOSR<sef><br/>SIOSR<uerr><br/>SCLK pin<br/>(output)<br/>SO pin<br/>(output)<br/>SS pin<br/></uerr></sef></siof></siof></siom></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | data A Writing data A Grant data A Writing data A Grant d |                                               |                   | and forced stop                      |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>SIOR <sios><br/>SIOSR<sion><br/>SIOSR<siof><br/>SIOSR<siof><br/>SIOSR<sef><br/>SIOSR<tbfl><br/>SIOSR<uerr><br/>SCLK pin<br/>(output)<br/>SO pin<br/>(output)<br/>SS pin<br/>(output)<br/>INTSIO<br/>SIOBUF</uerr></tbfl></sef></siof></siof></sion></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | data A Writing data A Grant data A Writing data A Grant d |                                               |                   | and forced stop                      |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>SIOR <sios><br/>SIOSR<siof><br/>SIOSR<siof><br/>SIOSR<tbfl><br/>SIOSR<tbfl><br/>SIOSR<uerr><br/>SCLK pin<br/>(output)<br/>SO pin<br/>(output)<br/>SS pin<br/>(output)<br/>SS</uerr></tbfl></tbfl></siof></siof></sios> | data A Writing data A Grant data A Writing data A Grant d | B-bit Transmit mod                            |                   | and forced stop Reserved stop        |                  |
| (write buffer)<br>Write to<br>SIOBUF<br>Writing<br>Start<br>SIOCR <sios><br/>SIOSR<siom><br/>SIOSR<siof><br/>SIOSR<siof><br/>SIOSR<sef><br/>SIOSR<tbfl><br/>SIOSR<uerr><br/>SIOSR<uerr><br/>SCLK pin<br/>(output)<br/>SO pin<br/>(output)<br/>SS pin<br/>(output)<br/>INTSIO<br/>SIOBUF</uerr></uerr></tbfl></sef></siof></siof></siom></sios>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | data A Writing data A Writing data A Grant A Writing data A Grant A A A A A A A A A A A A A A A A A A A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | B-bit Transmit mod                            |                   | and forced stop Reserved stop        | Bit5∕Bit6∕ Bit7  |

Figure 15.6 8-bit Transmit mode (External clock and occurrence of transmit underrun error)

## 15.5.2 8-bit Receive Mode

The 8-bit receive mode is selected by setting SIO0CR<SIOM> to"10".

## 15.5.2.1 Setting

Before starting the receive operation, select the transfer edges at SIO0CR<SIOEDG>, a transfer format at SIO0CR<SIODIR> and a serial clock at SIO0CR<SUICKS>. To use the internal clock as the serial clock, select an appropriate serial clock at SIO0CR<SUICKS>. To use an external clock as the serial clock, set SIO0CR<SOCKS> to "111"/

The 8-bit Receive mode is selected by setting SIO0CR<SIOM> to "10" Reception is started by setting SIO0CR<SIOS> to "1".

Writing data to SIOOCR<SIOEDG,SIOCKS and SIODIR> is invalid when the serial communication is in progress, or when SIOOSR<SIOF> is "1". Make these settings while the serial communication is stopped . While the serial communication is in progress<SIOOSR<SIOF>="1"), only writing "00" to SIOOCR<SIOM> or writing "0" to SIOOCR<SIOS> is valid.

## 15.5.2.2 Starting the receive operation

Reception is started by setting SIOOCR<SIOS> to "1". External serial data is taken into the shift register from the SIO pin according to the settings of SIOOCR<SIOEDG, SIOCKs and SIODIR>. Internal clock operation, the serial clock of the selected baud rate is output from the SCLKO pin. In the external clock operation, an external clock must be supplied to the SCLKO pin. By setting SIOOCR<SIOS> to "1", SIOOSR<SIOF and SEF> are automatically set to "1".

## 15.5.2.3 Operation on completion of reception

When the data reception is complete, the data is transferred from the shift register to SIOBUF and an INTSIO0 interrupt request is generated. The receive completion flag SIO0SR<REND> is set to "1".

In the operation with the internal clock, the serial clock output is stopped until the receive data is read from SIO0BUF(automatic wait). At this time, SIO0SR<SEF> is set to "0". By reading the receive data from SIO0BUF, SIO0SR<SEF> is set to "1", the serial clock output is restarted and the receive operation continues.

In the operation with an external clock, data can be continuously received without reading the received data from SIO0BUF. In this case, data must be red from SIO0BUF before the subsequent data has been fully received. If the subsequent data is received completely before reading data from SIO0BUF, the overrun error flag SIO0SR<OERR> is set to "1". When an overrun error has occurrence of an overrun error is discarded, and SIO0BUF holds the data value received before the occurrence of the overrun error.

## Page: 258 / 278

SIO0SR<REND> is cleared to "0" by reading data from SIO0BUF. SIO0SR<OERR> is cleared by reading SIO0SR.

## 15.5.2.4 Stopping the receive operation

Set SIO0CR<SIOS> to "0" to stop the receive operation. When SIO0SR<SEF> is "0", or when the shift operation is not in progress, the operation is stopped immediately. Unlike the transmit mode, no INTSIO0interrupt request is generated in this state.

When SIOOSR<SEF> is "1", the operation is stopped after the 8-bit data has been completely received (reserved stop). At this time, an INTSIOO interrupt request is generated. After the operation has stopped completely, SIOOSR<SIOF and SEF> are cleared to "0". Other SIOOSR registers keep their values.

The receive operation can be forced to stop by setting SIO0CR<SIOM> to "00" during the operation. By setting SIO0CR<SIOM> to "00", SIO0CR<SIOS> and SIO0SR are cleared to "0" and the SIO stops the operation, regardless of the SIO0SR<SEF> value. If the internal clock is selected, the SCLK0 pin returns to the initial level.



Figure 15.7 8-bit Receive Mode (Internal Clock and Reserved Stop)

## Page: 259 / 278

## 汉芝电子股份有限公司

iMQ Technology Inc.

| No   | · 7 | חחז | ς ∩ 1 | <b>Ν</b> Λ. | 6Q1 | 2-EN  |  |
|------|-----|-----|-------|-------------|-----|-------|--|
| INU. |     | שטו | וטב   | -101        | 001 | Z-LIN |  |

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

| Start                           | operation                                            |                                                              |               |                   |
|---------------------------------|------------------------------------------------------|--------------------------------------------------------------|---------------|-------------------|
| SIOCR <sios></sios>             | 1                                                    |                                                              |               |                   |
| siosr <siof></siof>             | ]                                                    |                                                              |               |                   |
| SIOSR <sef></sef>               |                                                      |                                                              |               |                   |
| siosr <rendb></rendb>           |                                                      | <br>!                                                        | <br> <br>     |                   |
| siosr <rend<u>b&gt;</rend<u>    |                                                      |                                                              |               |                   |
| Internal clock                  |                                                      | hunnun                                                       |               | minn              |
| SI pin<br>(input)               | data A<br>Bit0\Bit1\Bit2\Bit3\Bit4\Bit5\Bit5\Bit6\Bi | data B<br>1<br>17)Bit0)Bit1)Bit2)Bit3)Bit4)Bit5)Bit6)Bi<br>1 | data C        | Bit5XBit6XBit7    |
| SS pin<br>(output)              |                                                      |                                                              | <br>     <br> |                   |
|                                 |                                                      | h                                                            |               | <u>1</u>          |
| SIOBUF<br>(write buffer)        |                                                      | A                                                            |               | і<br>І <u>Х</u> В |
| READ<br>SIOBUF<br>READ<br>SIOSR |                                                      |                                                              | <br>          | Reading data A    |

## Figure 15.8 8-bit Receive Mode(External Clock and Occurrence of Overrun Error)

## 15.5.3 8-bit Transmit/receive mode

The 8-bit transmit/receive mode is selected by setting SIO0CR<SIOM> to "11".

## 15.5.3.1 Setting

Before starting the transmit/receive operation, select the transfer edges at SIO0CR<SIOEDG>, a transfer format at SIO0CR<SIODIR> and a serial clock at SIO0CR<SIOCKS>. To use the internal clock as

the serial clock, select an appropriate serial clock at SIO0CR<SIOCKS>. To use an external clock as the serial clock, set SIO0CR<SIOCKS> to "111".

The 8-bit transmit/receive mode is selected by setting SIOOCR<SIOM> to "11". The transmit/receive operation is started by writing the first byte of transmit data to SIO0BUF and then setting SIO0CR<SIOS> to "1".

Writing data to SIOOCR<SIOEDG, SIOCKS and SIODIR> is invalid when the serial communication is in progress, or when SIOOSR<SIOF> is "1". Make these settings while the serial communication is stopped. While the serial communication is in progress (SIOOSR<SIOF>="1"), only writing "00" to SIOCR<SIOM> or writing "0" to SIOCR<SIOS> is valid.

## Page: 260 / 278

## 15.5.3.2 Starting the transmit/receive operation

The transmit/receive operation is started by writing data to SIO0BUF and then setting SIO0CR<SIOS>

to "1". The transmit data is transferred from SIO0BUF to the shift register, and the serial data is transmitted from the SO0 pin according to the settings of SIO0CR<SIOEDG, SIOCKS and SIODIR>. At the same time, the serial data is received from the SI0 pin according to the settings of SIO0CR<SIOEDG, SIOCKS and SIODIR>.

In the internal clock operation, the serial clock of the selected baud rate is output from the SCLK0 pin. In the external clock operation, an external clock must be supplied to the SCLK0 pin.

The transmit data becomes undefined if the transmit/receive operation is started without writing any transmit data to SIO0BUF.

By setting SIO0CR<SIOS> to "1", SIO0SR<SIOF and SEF> are automatically set to "1" and an INTSIO0 interrupt request is generated.

SIOOSR<SEF> is cleared to "0" when the 8th bit of data is received.

## 15.5.3.3 Transmit buffer and shift operation

If any data is written to SIOOBUF when the serial communication is in progress and the shift register is empty, the written data is transferred to the shift register immediately. At this time, SIOOSR<TBFL> remains at "0".

If any data is written to SIO0BUF when some data remains in the shift register, SIO0SR<TBFL> is set

to "1". If new data is written to SIO0BUF in this state, the contents of SIO0BUF are overwritten by the new value. Make sure that SIO0SR<TBFL> is "0" before writing data to SIO0BUF.

## 15.5.3.4 Operation on completion of transmission/ reception

When the data transmission/reception is completed, SIO0SR<REND> is set to "1" and an INTSIO0 interrupt request is generated. The operation varies depending on the operating clock.

#### (a) When the internal clock is used

If SIO0SR<TBFL> is "1", it is cleared to "0" and the transmit/receive operation continues. If SIO0SR<REND> is already "1", SIO0SR<OERR> is set to "1".

If SIOOSR<TBFL> is "0", the transmit/receive operation is aborted. The SCLK0 pin becomes the initial state and the SO0 pin becomes the "H" level. SIOOSR<SEF> remains at "0". When the subsequent data is written to SIOOBUF, SIOOSR<SEF> is set to "1", the SCLK0 pin outputs the clock and the transmit/receive operation is restarted. To confirm the receive data, read it from SIOOBUF before writing data to SIOOBUF.

## Page: 261 / 278

#### (b) When external clock is used

The transmit/receive operation continues. If the external serial clock is input without writing any data to SIO0BUF, the last data value set to SIO0BUF is re-transmitted. At this time, the transmit underrun error flag SIO0SR<UERR> is set to "1".

When the next 8-bit data is received completely before SIO0BUF is read, or in the state of SIO0SR<REND>="1", SIO0SR<OERR> is set to "1".

### 15.5.3.5 Stopping the transmit/receive operation

Set SIO0CR<SIOS> to "0" to stop the transmit/receive operation. When SIO0SR<SEF> is "0", or when the shift operation is not in progress, the operation is stopped immediately. Unlike the transmit mode, no INTSIO0 interrupt request is generated in this state.

When SIO0SR<SEF> is "1", the operation is stopped after the 8-bit data is received completely. At this time, an INTSIO0 interrupt request is generated.

After the operation has stopped completely, SIO0SR<SIOF, SEF and TBFL> are cleared to "0". Other SIO0SR registers keep their values.

If the internal clock has been used, the SO0 pin automatically returns to the "H" level. If an external clock has been used, the SO0 pin keeps the last output value. To return the SO0 pin to the "H" level, write "00" to SIO0CR<SIOM> when the operation is stopped.

The transmit/receive operation can be forced to stop by setting SIO0CR<SIOM> to "00" during the operation. By setting SIO0CR<SIOM> to "00", SIO0CR<SIOS> and SIO0SR are cleared to "0" and the SIO stops the operation, regardless of the SIO0SR<SEF> value. The SO0 pin becomes the "H" level. If the internal clock is selected, the SCLK0 pin returns to the initial level.

## Page: 262 / 278

## 汉芝电子股份有限公司

iMQ Technology Inc.

| No. : TDDS01-M6812-EN                                          | Name : MQ6812/MQ68                                                     | 21/MQ6822 Datasheet                      | Version : V1.1                 |
|----------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------|--------------------------------|
| SIOCR <sios></sios>                                            |                                                                        | Reserved stop                            |                                |
| SIOSR <siof></siof>                                            |                                                                        | · · · ·                                  | ·>                             |
| SIOSR <sef></sef>                                              |                                                                        |                                          |                                |
| SIOSR <tbfl></tbfl>                                            |                                                                        |                                          |                                |
| SIOSR <rendb></rendb>                                          | i                                                                      |                                          |                                |
| Internal clock                                                 | uuuduuuu                                                               | minin                                    | unin                           |
| SCLK pin                                                       | mmhmm                                                                  |                                          |                                |
| SO pin<br>(output)                                             | data A data B<br>2/Bit3/Bit4/Bit5/Bit6/Bit7/Bit0/Bit1/Bit2/Bit3/Bit4/I | Bit5/Bit6/Bit7/ Bit0/Bit1/Bit2/Bit3/Bit4 | і<br> <br>Хвіт5Хвіт6Хвіт7У<br> |
| SI pin (input)                                                 | data D<br>2/Bit3/Bit4/Bit5/Bit6/Bit7/Bit0/Bit1/Bit2/Bit3/Bit4/R        | Bit5/Bit6/Bit7/ Bit0/Bit1/Bit2/Bit3/Bit4 | XBit5XBit6XBit7                |
| SS pin<br>(output)                                             |                                                                        |                                          |                                |
|                                                                | Ń                                                                      | hh                                       |                                |
| SIOBUFA<br>(write buffer)<br>Write to<br>SIOBUF Writing data A | المالية<br>المالية<br>Writing data B                                   | Vriting data C                           |                                |
| SIOBUF<br>(read buffer)<br>Read<br>SIOBUF                      | χ <sub>σ</sub>                                                         | ХЕ<br>                                   | К_Е                            |

Figure 15.9 8-bit Transmit/receive mode(External clock, occurrence of transmit underrun error and occurrence of overrun error)

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

## 15.6 AC Characteristic



### Figure 15.10 AC characteristics

(V<sub>SS</sub> = 0 V, V<sub>DD</sub> = 4.5 V - 5.5 V, Topr = -40 to 85°C)

| Parameter                     | Symbol             | Condition                                                            | Min                    | Тур. | Max                  | Unit |
|-------------------------------|--------------------|----------------------------------------------------------------------|------------------------|------|----------------------|------|
| SCLK cycle time               | tscy               |                                                                      | 2 / fcgck              | -    | -                    |      |
| SCLK "L" pulse width          | t <sub>SCYL</sub>  |                                                                      | 1 / fcgck<br>- 25      | -    | -                    |      |
| SCLK "H" pulse width          | tscyн              | Internal clock operation<br>SO pin and SCLK pin load capacity=100 pF | 1 / fcgck<br>- 15      | -    | -                    |      |
| SI input setup time           | t <sub>SIS</sub>   |                                                                      | 60                     | -    | -                    |      |
| SI input hold time            | t <sub>SIH</sub>   |                                                                      | 35                     | -    | -                    |      |
| SO output delay time          | t <sub>SOD</sub>   |                                                                      | -50                    | -    | 50                   | ns   |
| SCLK cycle time               | tscy               |                                                                      | 2 / fcgck              | -    | -                    |      |
| SCLK "L" pulse width          | tscyl              |                                                                      | 1 / fcgck              | -    | -                    |      |
| SCLK "H" pulse width          | t <sub>SCYH</sub>  | External clock operation                                             | 1 / fcgck              | -    | -                    |      |
| SI input setup time           | t <sub>SIS</sub>   | SO pin and SCLK pin load capacity=100 pF                             | 50                     | -    | -                    |      |
| SI input hold time            | t <sub>SIH</sub>   |                                                                      | 50                     | -    | -                    |      |
| SO output delay time          | t <sub>SOD</sub>   |                                                                      | 0                      | -    | 60                   |      |
| SCLK low-level input voltage  | t <sub>SCLKL</sub> |                                                                      | 0                      | -    | $V_{DD} \times 0.30$ | N    |
| SCLK high-level input voltage | t <sub>SCLKH</sub> |                                                                      | V <sub>DD</sub> × 0.70 | -    | V <sub>DD</sub>      | V    |



### Figure 15.11 Interval time between bytes

## Page: 264 / 278

# Appendix A. In-system Programming Function (ISP)

MQ6812/MQ6821 is equipped with ISP(In-System Programming). ISP function provide user to debug via MQ-Link and PC software operate. User can do software or system design adjustment by In-system programming function.

Folloing content will explain the control pin of ISP founction, and how to connect to target system.

## **Control Pin**

ISP function need two communication pins and three power and RESET pins. The pin description as table A.1; P40 and P41 are communication pins to ISP function.

| Pin description | Input/output | Function                      | Pin Description |
|-----------------|--------------|-------------------------------|-----------------|
| ISPCLK          | Input        | Communication pin(clock ctrl) | P40/AIN0/KWI0   |
| ISPDIO          | Input/Output | Communication pin (data ctrl) | P41/AIN1/KWI1   |
| RESETB          | Input        | Reset control pin             | RESETB          |
| VDD             | Power        | 5.0V                          | 2.0V to 5.5V    |
| VSS             | Power        | 0V                            |                 |

Table A.1 Control pin of ISP function

## How to connect MQ-Link to target system

To use ISP function, user have to link specific pins of target system to MQ-Link. iMQ would provide interface control cable. Set interface control cable to target system will make ISP function easier. User can refer to figure A.1. to link MQ-Link to target system.

## Page: 265 / 278



Figure A.1 Link MQ-Link to target system

Note1 : If the reset circuit of system board will effect ISP function, please use jumper or switch to disconnect.

Note2 : When operate ISP function, the MO-Link would supply VDD to MCU of target system. After ISP procedure finish, the target system would supply VDD to MCU.

Note3 : Detail of MO-Link , please see "iMO i87 IDE user manual".

## Page: 266 / 278

| o. : TDD         | S01-M6812     | -EN        | Name : MQ6812/MQ6821/MQ6822 Datasheet |            |           | sheet Version : V1.1 |           |            | /1.1 |   |   |   |
|------------------|---------------|------------|---------------------------------------|------------|-----------|----------------------|-----------|------------|------|---|---|---|
| Appe             | ndix B.       | Prod       | duct num                              | ber infori | matic     | n                    |           |            |      |   |   |   |
| xample :         |               |            |                                       | MQ         | <u>68</u> | <u>12</u>            | <u>SP</u> | <u>028</u> | Ĥ    | Α | Ę | R |
|                  |               |            |                                       |            |           |                      |           |            | Т    | T | T | Τ |
| 10               |               |            |                                       |            |           |                      |           |            |      |   |   |   |
| oduct Se         | eries ——      |            |                                       |            |           |                      |           |            |      |   |   |   |
| b Series         |               |            |                                       |            |           |                      |           |            |      |   |   |   |
| ickage T         |               | 1          |                                       | 1          |           |                      |           |            |      |   |   |   |
| Code             | Package type  |            | Package type                          |            |           |                      |           |            |      |   |   |   |
| ST               | SOT23         | SD         | SDIP                                  |            |           |                      |           |            |      |   |   |   |
| SP               | SOP           | LQ         | LOFP 7x7                              |            |           |                      |           |            |      |   |   |   |
| MS               | MSOP          | LA         | LQFP 10x10                            |            |           |                      |           |            |      |   |   |   |
| SS               | SSOP          | LE         | LOFP 14x14                            |            |           |                      |           |            |      |   |   |   |
| DP<br>TS         | PDIP<br>TSOP  | N4<br>N5   | QFN 4x4<br>QFN 5x5                    |            |           |                      |           |            |      |   |   |   |
| DS               | TSOP          |            | QFIN 5X5                              |            |           |                      |           |            |      |   |   |   |
| 23               | 13306         |            |                                       |            |           |                      |           |            |      |   |   |   |
| n count          |               |            |                                       |            |           |                      |           |            |      |   |   |   |
| Code             | Pin count.    | Code       | Pin count.                            |            |           |                      |           |            |      |   |   |   |
| 005              | 5             | 032        | 32                                    |            |           |                      |           |            |      |   |   |   |
| 006              | 6             | 036        | 36                                    |            |           |                      |           |            |      |   |   |   |
| 008              | 8             | 040        | 40                                    |            |           |                      |           |            |      |   |   |   |
| 010              | 10            | 044        | 44                                    |            |           |                      |           |            |      |   |   |   |
| 014              | 14            | 048        | 48                                    |            |           |                      |           |            |      |   |   |   |
| 016              | 16            | 064        | 64                                    |            |           |                      |           |            |      |   |   |   |
| 020              | 20<br>24      | 080<br>096 | 80                                    |            |           |                      |           |            |      |   |   |   |
| 024              | 24            | 100        | 100                                   |            |           |                      |           |            |      |   |   |   |
| 020              | 20            | 100        | 100                                   |            |           |                      |           |            |      |   |   |   |
| ogram F          | lash —        |            |                                       |            |           |                      |           |            |      |   |   |   |
| ata Flash        |               |            |                                       |            |           |                      |           |            |      |   |   |   |
| AM               |               |            |                                       |            |           |                      |           |            |      |   |   |   |
| Progr            | am Flash/     | Carl       | Program Flash/                        |            |           |                      |           |            |      |   |   |   |
| ode Data<br>Size | flash/RAM     |            | Data flash/RAM<br>Size                |            |           |                      |           |            |      |   |   |   |
|                  | 128 Bytes     | К          | 24K Bytes                             |            |           |                      |           |            |      |   |   |   |
|                  | 256 Bytes     | М          | 32K Bytes                             |            |           |                      |           |            |      |   |   |   |
|                  | 512 Bytes     | Ν          | 40K Bytes                             |            |           |                      |           |            |      |   |   |   |
|                  | 1K Bytes      | Р          | 48K Bytes                             |            |           |                      |           |            |      |   |   |   |
|                  | 2K Bytes      | S          | 64K Bytes                             |            |           |                      |           |            |      |   |   |   |
|                  | 4K Bytes      | U<br>W     | 96K Bytes                             |            |           |                      |           |            |      |   |   |   |
|                  | 8K Bytes      |            | 128K Bytes<br>毎                       |            |           |                      |           |            |      |   |   |   |
|                  | 12K Bytes     | V          | 無                                     |            |           |                      |           |            |      |   |   |   |
| H<br>perating    | 16K Bytes     |            |                                       |            |           |                      |           |            |      |   |   |   |
|                  | perating temp |            |                                       |            |           |                      |           |            |      |   |   |   |
| R                | -40~85°C      |            |                                       |            |           |                      |           |            |      |   |   |   |
| X                | -40~105°C     |            |                                       |            |           |                      |           |            |      |   |   |   |
| Т                | -40~125°C     |            |                                       |            |           |                      |           |            |      |   |   |   |

汉芝电子股份有限公司 iMQ Technology Inc. No. : TDDS01-M6812-EN Name : MQ6812/MQ6821/MQ6822 Datasheet Version: V1.1 Appendix C. Package Information LQFP 32 7x7 (Product No.: MQ6812LQ032HAER)  $-0.4 \times 45^{\circ}$  (4×) 1000,0000 (+)2 5 DAMBAR REST SCALE 4:1 GUAGE PLANE 637 \_ ΩYS R1 0.637 0.127A3 mm Symbol MIN. Normal MAX. WITH PLATING -BASE METAL А 1.45 1.55 1.65 SECTION A-A A1 0.01 \_\_\_ 0.21 1.5 A2 1.3 1.4 A3 0.254 \_\_\_ 0.30 0.35 0.40 b b1 0.31 0.37 0.43 \_\_\_ 0.127 \_\_\_ с D1 6.85 6.95 7.05 D2 6.9 7.00 7.10 Е 8.8 9.00 9.20 Ε1 6.85 6.95 7.05 E2 7.00 7.10 6.9 e 0.8 ---\_\_\_ 0.71 L 0.43 ---L1 0.90 1.0 1.10 R 0.25 0.1 \_\_\_ R1 0.1 \_\_\_ \_\_\_ θ 0 10° θ1 0 \_\_\_ \_\_\_ 0.1 --y ---Ζ 0.70 \_\_\_ \_\_\_

## Page: 268 / 278

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

#### (Product No.: MQ6812N4032HAER) QFN 32 4x4







|        | mm   |           |      |  |  |  |
|--------|------|-----------|------|--|--|--|
| Symbol | MIN. | NORMAL    | MIN. |  |  |  |
| А      | 0.70 | 0.75      | 0.80 |  |  |  |
| A1     | 0.00 | 0.02      | 0.05 |  |  |  |
| A3     |      | 0.203 REF |      |  |  |  |
| b      | 0.15 | 0.20      | 0.25 |  |  |  |
| D      |      | 4.00 BSC  |      |  |  |  |
| Е      |      | 4.00 BSC  |      |  |  |  |
| е      |      | 0.40 BSC  |      |  |  |  |
| D2     | 2.60 | 2.75      | 2.90 |  |  |  |
| E2     | 2.60 | 2.75      | 2.90 |  |  |  |
| L      | 0.25 | 0.35      | 0.45 |  |  |  |

汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

# SSOP 28 (Product No.: MQ6812SS028HAER)



|        | mm      |        |       |  |  |
|--------|---------|--------|-------|--|--|
| Symbol | MIN.    | NORMAL | MIN.  |  |  |
| А      |         | -      | 2.00  |  |  |
| A1     | 0.05    | _      | 0.25  |  |  |
| A2     | 1.65    | 1.75   | 1.85  |  |  |
| A3     | 0.75    | 0.80   | 0.85  |  |  |
| b      | 0.29    | _      | 0.37  |  |  |
| b1     | 0.28    | 0.30   | 0.33  |  |  |
| С      | 0.15    | _      | 0.20  |  |  |
| c1     | 0.14    | 0.15   | 0.16  |  |  |
| D      | 10.00   | 10.20  | 10.40 |  |  |
| E      | 7.60    | 7.80   | 8.00  |  |  |
| E1     | 5.10    | 5.30   | 5.50  |  |  |
| е      | 0.65BSC |        |       |  |  |
| L      | 0.55    | 0.75   | 0.95  |  |  |
| L1     | 1.25BSC |        |       |  |  |
| θ      | 0       | -      | 10°   |  |  |

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

S

Version: V1.1

#### (Product No.: MQ6812SP028HAER) SOP 28







| 6 L    |        | mm     |        |
|--------|--------|--------|--------|
| Symbol | MIN.   | NORMAL | MIN.   |
| А      | 2.465  | 2.515  | 2.565  |
| A1     | 0.10   | 0.15   | 0.20   |
| A2     | 2.1    | 2.3    | 2.5    |
| A3     | -      | 0.274  | -      |
| В      | 0.356  | 0.406  | 0.456  |
| b1     | 0.366  | 0.426  | 0.486  |
| С      | -      | 0.254  | -      |
| D1     | 17.750 | 17.950 | 18.150 |
| D2     | 17.8   | 18.0   | 18.2   |
| E      | 10.1   | 10.3   | 10.500 |
| E1     | 7.374  | 7.450  | 7.574  |
| E2     | 7.424  | 7.500  | 7.624  |
| e      | -      | 1.270  | -      |
| L      | 0.764  | 0.864  | 0.964  |
| L1     | 1.303  | 1.403  | 1.503  |
| R      | -      | 0.2    | -      |
| R1     | _      | 0.3    | -      |
| θ      | 0      | -      | -      |
| θ1     | 0      | -      | 10°    |
| у      | -      |        | 0.1    |
| Z      | _      | 0.745  | -      |



| b1 | 0.366  | 0.426  | 0.486  |
|----|--------|--------|--------|
| с  |        | 0.254  | -      |
| D1 | 12.500 | 12.700 | 12.900 |
| D2 | 12.550 | 12.750 | 12.950 |
| E  | 10.206 | 10.306 | 10.406 |
| E1 | 7.400  | 7.450  | 7.500  |
| E2 | 7.450  | 7.500  | 7.550  |
| е  |        | 1.270  | -      |
| L  | 0.800  | 0.864  | 0.900  |
| L1 | 1.303  | 1.403  | 1.503  |
| R  |        | 0.200  | -      |
| R1 |        | 0.300  | _      |
| θ  | 0      | _      | _      |
| θ1 | 0      | _      | 10°    |
|    |        |        |        |

0.406

0.456

0.356

b

汉芝电子股份有限公司

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1





| Symbol         | mm       |        |      |  |
|----------------|----------|--------|------|--|
|                | MIN.     | Normal | MIN. |  |
| А              | _        | _      | 1.75 |  |
| A1             | 0.10     | -      | 0.25 |  |
| A2             | 1.30     | 1.40   | 1.50 |  |
| A3             | 0.60     | 0.65   | 0.70 |  |
| b              | 0.23     | -      | 0.33 |  |
| ʻb1            | 0.22     | 0.25   | 0.28 |  |
| с              | 0.21     | -      | 0.26 |  |
| ʻc1            | 0.19     | 0.20   | 0.21 |  |
| D              | 8.45     | 8.65   | 8.85 |  |
| E              | 5.80     | 6.00   | 6.20 |  |
| E1             | 3.70     | 3.90   | 4.10 |  |
| е              | 0.635BSC |        |      |  |
| h              | 0.25     | -      | 0.50 |  |
| L              | 0.50     | -      | 0.80 |  |
| L1             | 1.05BSC  |        |      |  |
| θ              | 0        | -      | 80   |  |
| L/F size (mil) | 96*140   |        |      |  |

iMQ Technology Inc.

No. : TDDS01-M6812-EN

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

#### (Product No.: MQ6821DP020HAER) DIP 20





| Symbol | mm     |        |        |  |
|--------|--------|--------|--------|--|
|        | MIN.   | Normal | MIN.   |  |
| А      | -      | _      | 4.445  |  |
| A1     | 0.381  | -      | -      |  |
| A2     | 3.175  | 3.302  | 3.429  |  |
| В      | 0.406  | 0.457  | 0.508  |  |
| B1     | 1.473  | 1.524  | 1.626  |  |
| С      | 0.203  | 0.254  | 0.279  |  |
| D      | 25.705 | 26.060 | 26.416 |  |
| E      | 7.366  | 7.620  | 7.874  |  |
| E1     | 6.223  | 6.350  | 6.477  |  |
| e1     | 2.286  | 2.540  | 2.794  |  |
| L      | 3.048  | 3.302  | 3.556  |  |
| θ°     | 0      | -      | 15     |  |
| eA     | 8.509  | 9.017  | 9.525  |  |
| S      | _      | _      | 1.905  |  |

Name : MQ6812/MQ6821/MQ6822 Datasheet

Version: V1.1

# Appendix D. Application Notice

## (A) 10-bit PPG

PGG output level is effective from 2<sup>nd</sup> period, the level cannot be set by register. When PPG finished, set the pin to I/O function ,then to eliminate the un-known level by I/O output.



Name : MQ6812/MQ6821/MQ6822 Datasheet

## (B) 10-bit timer/counter (TCQ0)

- 1. Only TCQ00, TCQ02, TCQ04 can use double buffer (detail refer to figure 10-11 and 10-15)
- 2. PPG pulse output do not support duty as 0% and 100%.

## (C) Pin related

1. Transfer P10 form RESTEB to I/O, or I/O to RESETB, when P10 is stable high leve. If transfer P10 when the status is low-level, it may cause reset.

2. The oscillator of PCBA should closed to MCU as possible.

3. When P2OUTCR4 or P2OUTCR3 is "1" (P23,P24 set to open-drain pin), the IDD woud increase dozens uA in STOP mode.

4. The I/O pins which need to be pull-up or pull-low should be connected to VDD or GND through a resistor(resistance > 100 ohm). To connect I/O pins to VDD or GND directly should be avoided .

## (D) Operation mode and clock switch

1. In the time period from stop mode enabled to system wake up · the interrupts latches may set to "1" by external interrupt signal changed, and the system interrupt immediately when exit stop mode. Before stop mode enable, it is suggested to stop all interrupts. If it would enable any interrupts after exiting stop mode, it need to clear non-used interrupts latches.

2. Set SYSCR2<XEN> to"1" when POFC0 is "0", the system clock would reset.

3. Transfer the clock, set the new clock first, then closed original clock. 4. Bit6~Bit3 is related to chip modifying when record the chip by writer. Please user use "bit operation" for programming. "SET (FSCTRL).0」" or "CLR (FSCTRL).0" for example. Do not use other bit to change the value of Bit 6~Bit3.5. In SLOW mode, do not change CGCR<FCGCKSEL> °

6. Set SYSCR2<XEN> to "1" · system clock would be reset when POFC0 set to "0". If P00 or P01 is not used as port, set POFC0 to "1".

## (E) ADC

1. In single mode, do not read ADCDRL or ADCDRH. If ADC finished between read ADCDRL and ADCDRH, then INTADC interrupt would be cancel, and lost the result of convert.

2. Read ADCDRL first then read ADCDRH. If read ADCDRH first then read ADCDRL or read ADCDRL only, it would not clear ADCCR2<EOCF>. The ADC interrupt would not occur.

3. MQ6812/ MQ6821 contains auto-calibration function. Detail please refer the application note on the website.

http://www.imqtech.com/zh-hant/tech/technicaldocuments/application\_notes

## (F) Timer

1.When a write instruction is executed on TAODRAL (TAODRBL), the data is first stored into this temporary buffer, whether the double buffer is enabled or disabled. Subsequently, when a write instruction is executed on TAODRAH (TAODRBH), the set value is stored into the double buffer or TAODRAH (TAODRBH). At the same time, the set value in the temporary buffer is stored into the double buffer or TAODRAL (TAODRBL). (This structure is designed to enable the set values of the lower-level register and the higher-level register simultaneously.) Therefore, when setting data to TAODRA (TAODRB), be sure to write the data into TAODRAL and TAODRBH) in this order.

## Page: 276 / 278

Name : MQ6812/MQ6821/MQ6822 Datasheet

2. Because the WDT/WDT2 of MQ6812/MQ6821 are fixed and cannot be stopped , please clear WDT/WDT2 per 1.5 second at lease.

## <u>(G) LVD</u>

1. The comparotor of LVD do not include Hysteretic architecture. When VDD close to LDxLVL, it may cause INTLVD requests occurred frequently. When VDD decrease to detected voltage or VDD increase to detected voltage, it would generate INTLVD request in both conditions.

## (H) Interrupt

1. Under interrupt service process, IMF would be "0" automatically. If use multi-interupts, control IL before setting IMF to "1".

2. If use multi-interupts, setting IMF to "1" after setting every EF.

## <u>(I) I2C</u>

1. Before enable I2C function ,set related register as below :

- -Low power consumption register1 (POFFCR1)
- Set POOFFCR1<SBI0EN> to"1", before enable SBI/I2C function, unless the SBI/I2C setting is invalid.
- -Port P2 Output Control Registe (P2OUTCR)
- Set P2OUTCR3 and P2OUTCR4 to"1", before enable SBI/I2C function
- Port P2 Output Latch Register (P2DR) Set P2DR to"0" before enable SBI/I2C function, unless the SBI/I2C function would operate unexpectedly.

## (J) Instruction

Instruction "JP gg(note 1)" in extreme condition may cause next instruction code cannot be read correctly. Suggested to modified the code as below:

Note 1: gg is 16-bit general buffer WA, BC, DE, HL, IX, IY....

Page: 277 / 278

汉芝电子股份有限公司 iMQ Technology Inc. No. : TDDS01-M6812-EN Name : MQ6812/MQ6821/MQ6822 Datasheet Version: V1.1

Suggest to add a "NOP instruction" between SWITCH and the 1<sup>st</sup> case.

```
Original
switch(variable){
case 0:
    :
break;
case 1:
   :
break;
    :
default:
break;
}
```

```
modified
switch(variable){
 asm ("NOP");//add this instruction
 case 0:
    :
break;
 case 1:
    :
break;
    :
default:
break;
}
```

The function these two program are the same. The modified code compilered by MQ-Link would appear "I87C1-Warning-538" (as below), this message can be ignored.

| °C:\iMQ\iMQ IDE Y21D 20160825\tools\i87\bin\CCI87.exe″ −w1       | -03 -g -A -1 -XS   | -Nel -e -o "nain.rel" | "C:\application_source_code_ide\codes_20151025\main.c" |
|------------------------------------------------------------------|--------------------|-----------------------|--------------------------------------------------------|
| C:\application_source_code_ide\codes_20161028\nain_c_1007;       | 16TC1-Warning-538: | Statement not reached |                                                        |
| C:\application_source_code_ide\codes_20161028\main_c_1541:       | ISTC1-Warning-538: | Statement not reached |                                                        |
| C:\application_source_code_ide\codes_20161028\nain_c_1676;       | 18TC1-Warning-538: | Statement not reached |                                                        |
| C:\application_source_code_ide\codes_20161028\nain_c_2067;       |                    |                       |                                                        |
| <u>C'\annlication_source_code_ide\codes_20161026\nain_c_2068</u> | TSTC1=Kerning=538: | Statement not reached |                                                        |